前端之家收集整理的这篇文章主要介绍了
H5压缩图片 AJAX上传图片,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
HTML5 Canvas压缩图片 AJAX上传图片
Canvas压缩图片
@H_403_6@封装压缩图片的js
function compress(event,callback){
var file = event.files[0];
var reader = new FileReader();
reader.onload = function (e) {
var image = $('<img />');
image.on('load',function () {
var canvas = document.createElement('canvas');
var width = this.width;
var height = this.height;
canvas.width = this.width;
canvas.height = this.height;
var context = canvas.getContext('2d');
context.clearRect(0,0,width,height);
context.drawImage(this,this.width,this.height);
var quality = 0.9;
var data ;
var result;
var length;
do{
data= canvas.toDataURL('image/jpeg',quality);
length = data.length;
result = ((length/4)*3+1023)/1024;
console.log("result:"+result);
quality-=0.05;
}while(result>450);
callback(data);
});
image.attr('src',e.target.result);
};
reader.readAsDataURL(file);
}
@H_403_6@调用compress方法获取base64图片编码并使用AJAX上传
compress($("#imgID"),function(base64Img){
$.ajax({
type:"POST",url:$("#basePath").val()+"material/uploadMaterial",data:{
base64Img : base64Img
},success:function(data){
var result = eval('(' + data + ')');
if(result =='SUC'){
alert("上传成功");
return false;
}else{
alert("上传失败,请稍后重试");
return false;
}
}
});
});
@H_403_6@UploadController.java
import java.awt.image.BufferedImage
import java.io.ByteArrayInputStream
import java.io.File
import java.io.IOException
import java.util.UUID
import javax.imageio.ImageIO
import javax.servlet.http.HttpServletRequest
import javax.servlet.http.HttpServletResponse
import org.apache.log4j.Logger
import org.springframework.beans.factory.annotation.Autowired
import org.springframework.beans.factory.annotation.Qualifier
import org.springframework.stereotype.Controller
import org.springframework.web.bind.annotation.RequestMapping
import org.springframework.web.bind.annotation.ResponseBody
import sun.misc.BASE64Decoder
@Controller
@RequestMapping(value="/upload")
public class UploadController {
private static final Logger logger = Logger.getLogger(UploadController.class)
@ResponseBody
@RequestMapping("/uploadImg")
public synchronized String uploadImg(String base64Img,HttpServletRequest request,HttpServletResponse response)
throws IllegalStateException,IOException{
logger.info("uploadMaterial#####图片...")
String imgName
String imgPath
imgName=UUID.randomUUID().toString().replace("-","")+".jpeg"
imgPath="/app/mount/imageServer/material/"+imgName
String[] strs=base64Img.split(",")
//System.out.println("base64:"+strs[1])
try {
String data =savePictoServer(strs[1],imgPath)
logger.info("--->>>图片上传成功!::"+data)
return "SUC"
} catch (Exception e) {
logger.info("uploadMaterial######图片转化异常......")
return "图片上传失败,请稍后重试"
}
}
//图片上传
public static String savePictoServer(String base64String,String path)throws Exception{
BASE64Decoder decoder = new sun.misc.BASE64Decoder()
byte[] bytes1 = decoder.decodeBuffer(base64String)
ByteArrayInputStream bais = new ByteArrayInputStream(bytes1)
BufferedImage bi1 =ImageIO.read(bais)
File dir=new File(path)
if(!dir.exists()){
dir.mkdirs()
}
String fileName=path
File w2 = new File(fileName)
ImageIO.write(bi1,"jpg",w2)
return fileName
}
}
@H_403_6@使用到的jar包
@H_
403_6@catalina-manager.jar、commons-fileupload-1.2.1.jar、commons-io-1.3.2.jar