使用spring mvc+localResizeIMG实现HTML5端图片压缩上传
第一步:下载localResizeIMG
localResizeIMG放在github中的,地址是:https://github.com/think2011/localResizeIMG。
第二步:在web工程中导入localResizeIMG相关js
解压localResizeIMG压缩吧,把目录中的dist文件夹拷贝到工程中,我的是放在js目录下。
然后在自己的js中导入jQuery和localResizeIMG的js。如:
<script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.min.js"></script>
<script type="text/javascript" src="js/lrz.bundle.js"></script>
第三步:在自己的上传的input的file框加入onchange事件如下代码在fileChange方法中实现代码的压缩和对压缩后生成的base64异步传到后台
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title></title>
</head>
<body>
<p>图片压缩上传案例</p>
<input type="file" id="payfile"/>
<input type="button" value="压缩后上传" οnclick="fileChange()"/>
<script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.min.js"></script>
<script type="text/javascript" src="js/lrz.bundle.js"></script>
<script type="text/javascript">
function fileChange() {
var img = document.getElementById('payfile');
//以图片宽度为800进行压缩
lrz(img.files[0],{
width:500,
height:500
}).then(function(rst) {
var img = rst.base64;
//压缩后异步上传
$.post({
url: "http://192.168.1.112:8085/NewHRHServer/common/images/fileUploadPicture",
data: {
imgdata: img //压缩后的base值
},
success: function(data) {
alert(data)
},error:function(data){
console.log(data)
}
});
});
}
</script>
</body>
</html>
第四步:spring mvc controller 后台接收base值并解析并保存文件
@RequestMapping("/fileUploadPicture")
public void uploadImg(String imgdata, HttpServletResponse response) throws IOException {
BASE64Decoder decoder = new BASE64Decoder();
String imgPath = SysConfig.avatarsDir + "/1112.jpg";
// new一个文件对象用来保存图片,默认保存当前工程根目录
File imageFile = new File(imgPath);
// 创建输出流
FileOutputStream outputStream;
try {
outputStream = new FileOutputStream(imageFile);
// 获得一个图片文件流,我这里是从flex中传过来的
byte[] result = decoder.decodeBuffer(imgdata.split(",")[1]);//解码
for (int i = 0; i < result.length; ++i) {
if (result[i] < 0) {// 调整异常数据
result[i] += 256;
}
}
outputStream.write(result);
PrintWriter pw = response.getWriter();
pw.write("success");
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET 9 new features-C#13新的锁类型和语义
· Linux系统下SQL Server数据库镜像配置全流程详解
· 现代计算机视觉入门之:什么是视频
· 你所不知道的 C/C++ 宏知识
· 聊一聊 操作系统蓝屏 c0000102 的故障分析
· DeepSeek V3 两周使用总结
· 回顾我的软件开发经历(1)
· C#使用yield关键字提升迭代性能与效率
· 低成本高可用方案!Linux系统下SQL Server数据库镜像配置全流程详解
· 4. 使用sql查询excel内容