JS 实现上传照片到服务器 和 后台处理处理这个照片

6 篇文章 0 订阅
1 篇文章 0 订阅

1.js进行图片预览 使用input标签来选择图片,使用FileReader读取图片并转成base64编码,然后发送给服务器。

<html>
<body>
 <img id="image"src=""/>
<br/>
 <input type="file"οnchange="selectImage(this);"/>
<br/>
 <input type="button"οnclick="uploadImage();"value="提交"/>
<script>
 var image = '';
 function selectImage(file){
 if(!file.files || !file.files[0]){
return;
}
 var reader = new FileReader();
 reader.onload = function(evt){
 document.getElementById('image').src = evt.target.result;
 image = evt.target.result;
}
reader.readAsDataURL(file.files[0]);
}
 function uploadImage(){

$.ajax({

type:'POST',

 url: 'ajax/uploadimage', 

 data: {image: image},

 async: false,

 dataType: 'json',

 success: function(data){

if(data.success){

alert('上传成功');

}else{

alert('上传失败');

}

},

 error: function(err){

alert('网络故障');

}

});

}
</script>
 <script src="jquery-1.11.1.min.js"></script>
</body>
</html>
2.服务器接收数据,然后写到磁盘
[java]  view plain  copy
  1. import java.io.FileOutputStream;  
  2. import java.io.IOException;  
  3.   
  4. import javax.servlet.ServletException;  
  5. import javax.servlet.http.HttpServlet;  
  6. import javax.servlet.http.HttpServletRequest;  
  7. import javax.servlet.http.HttpServletResponse;  
  8.   
  9. import sun.misc.BASE64Decoder;   
  10.   
  11. /** 
  12.  * 上传图片。 
  13. */  
  14. public class UploadImageAjax extends HttpServlet {  
  15.   
  16.   
  17. private static final long serialVersionUID = 1L;  
  18.   
  19.   
  20. @Override  
  21.   
  22. protected void doPost(HttpServletRequest req, HttpServletResponse resp)  
  23.   
  24.  throws ServletException, IOException{  
  25.   
  26.   
  27.   
  28.   
  29.   
  30. String image = req.getParameter("image");  
  31.   
  32.   
  33.   
  34.   
  35.   
  36. // 只允许jpg  
  37.   
  38.   
  39. String header ="data:image/jpeg;base64,";  
  40.   
  41.   
  42. if(image.indexOf(header) != 0){  
  43.   
  44.   
  45.   
  46. resp.getWriter().print(wrapJSON(false));  
  47.   
  48.   
  49.   
  50. return;  
  51.   
  52.   
  53. }  
  54.   
  55.   
  56.   
  57.   
  58.   
  59. // 去掉头部  
  60.   
  61.   
  62. image = image.substring(header.length());  
  63.   
  64.   
  65.   
  66.   
  67.   
  68. // 写入磁盘  
  69.   
  70.   
  71. boolean success = false;  
  72.   
  73.   
  74. BASE64Decoder decoder = new BASE64Decoder();  
  75.   
  76.   
  77. try{  
  78.   
  79.   
  80.   
  81. byte[] decodedBytes = decoder.decodeBuffer(image);  
  82.   
  83.   
  84.   
  85. String imgFilePath ="D://uploadimage.jpg";  
  86.   
  87.   
  88.   
  89. FileOutputStream out = new FileOutputStream(imgFilePath);  
  90.   
  91.   
  92.   
  93. out.write(decodedBytes);  
  94.   
  95.   
  96.   
  97. out.close();  
  98.   
  99.   
  100.   
  101. success = true;  
  102.   
  103.   
  104. }catch(Exception e){  
  105.   
  106.   
  107.   
  108. success = false;  
  109.   
  110.   
  111.   
  112. e.printStackTrace();  
  113.   
  114.   
  115. }  
  116.   
  117.   
  118.   
  119.   
  120.   
  121. resp.getWriter().print(wrapJSON(success));  
  122.   
  123. }  
  124.   
  125.   
  126.   
  127. private String wrapJSON(boolean success){  
  128.   
  129.   
  130. return"{"success":"+ success +"}";  
  131.   
  132. }  
  133. }  
3.配置文件web.xml
[xml]  view plain  copy
  1. <web-app>  
  2. <servlet>  
  3. <servlet-name>UploadImage</servlet-name>  
  4. <servlet-class>UploadImageAjax</servlet-class>  
  5. </servlet>  
  6. <servlet-mapping>  
  7. <servlet-name>UploadImage</servlet-name>  
  8. <url-pattern>/ajax/uploadimage</url-pattern>  
  9. </servlet-mapping>  
  10. </web-app>  
4.需要注意的地方 需要jquery的支持:jquery-1.11.1.min.js 需要servlet的支持:servlet-api.jar 需要Base64解码支持:sun.misc.BASE64Decoder。引入这个包eclipse可能会报错,请按照 http://blog.csdn.net/hurryjiang/article/details/6958146 进行处理。

http://www.thinksaas.cn/topics/0/348/348211.html
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值