本帖最后由 xiaoshuang1990 于 2010-10-18 15:40:05 编辑

解决方案 »

  1.   

     <img src="demo.gif" onload="if(this.width>300)this.width=300">或者
    <script language="JavaScript">
    <!--
    //图片按比例缩放
    var flag=false;
    function DrawImage(ImgD,iwidth,iheight){
    //参数(图片,允许的宽度,允许的高度)
    var image=new Image();
    image.src=ImgD.src;
    if(image.width>0 && image.height>0){
    flag=true;
    if(image.width/image.height>= iwidth/iheight){
    if(image.width>iwidth){ 
    ImgD.width=iwidth;
    ImgD.height=(image.height*iwidth)/image.width;
    }else{
    ImgD.width=image.width; 
    ImgD.height=image.height;
    }
    ImgD.alt=image.width+"×"+image.height;
    }
    else{
    if(image.height>iheight){ 
    ImgD.height=iheight;
    ImgD.width=(image.width*iheight)/image.height; 
    }else{
    ImgD.width=image.width; 
    ImgD.height=image.height;
    }
    ImgD.alt=image.width+"×"+image.height;
    }
    }

    //-->
    </script>
    调用:<img src="images/toplogo.gif" onload="javascript:DrawImage(this,100,100)">
     
      

  2.   

    如果想在后台做,就需要首先上传
    然后BufferedImage bsrc = ImageIO.read(new File(filepath));
    int width = bsrc.getWidth();
    int height = bsrc.getHeight();
    但是这并没有避免上传,如果图片很大...
    我觉得在前台做好一点