微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用ajaxfileupload.js实现上传文件功能

一直以来上传文件都是使用form表单上传文件,也看到过有人使用js上传文件,不过看起来蛮简单的也就没有怎么去理会。今天突然要使用这种方式上传文件,期间还遇到点问题。因此就记录下来,方便以后遇到这样的问题可以查看。

首先就是引入js和ajaxfileupload的文件,这个不需要多说。

然后就是ajax请求后台地址代码如下:

rush:xhtml;">
Box pos-rel"> 文件

$("#upload").on("change",function(){
$.ajaxFileUpload({
url : '/test/user/imgUpload',//后台请求地址
type: 'post',//请求方式 当要提交自定义参数时,这个参数要设置成post
secureuri : false,//是否启用安全提交,认为false。
fileElementId : 'upload',// 需要上传文件域的ID,即<input type="file">的ID。
dataType : 'json',//服务器返回的数据类型。可以为xml,script,json,html。如果不填写,jQuery会自动判断。如果json返回的带pre,这里修改为json即可解决
success : function (json,status) {//提交成功后自动执行的处理函数,参数data就是服务器返回的数据。
alert(json.retMsg);
},error : function (json,status,e) {//提交失败自动执行的处理函数

  }
});

});

前台代码完成就开始开发后台代码了。

rush:java;"> package com.roc.test;import java.io.File;import java.util.List; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.ws.rs.Consumes; import javax.ws.rs.POST; import javax.ws.rs.Path; import javax.ws.rs.Produces; import javax.ws.rs.QueryParam; import javax.ws.rs.core.Context; import javax.ws.rs.core.MediaType; import net.sf.json.JSONObject; import org.apache.commons.fileupload.FileItem; import org.apache.commons.fileupload.disk.diskFileItemFactory; import org.apache.commons.fileupload.servlet.ServletFileUpload; import org.jboss.resteasy.annotations.providers.jaxb.json.BadgerFish; import org.springframework.stereotype.Controller;import net.sf.json.JSONObject;/** * 上传文件 * @author liaowp * */ @Controller @Path("/user") public class UploadImg {

@Path("/imgUpload")
@POST
@Produces("application/json; charset=utf-8")
@Consumes(MediaType.MULTIPART_FORM_DATA )
@BadgerFish
public JSONObject upload(@QueryParam("orderId") String orderId,@Context HttpServletRequest request,@Context HttpServletResponse response) {
JSONObject jsonobj = new JSONObject();
String file_path=request.getSession().getServletContext().getRealPath("/")+File.separator+"corpfile"+File.separator;//文件存储路径
String upload_file_path="";
File file =new File(file_path);
if(!file.exists() && !file.isDirectory()){ //如果文件夹不存在则创建
file.mkdir();
upload_file_path=file_path;
}else{
upload_file_path=file_path;
}
diskFileItemFactory factory = new diskFileItemFactory(); // 设置工厂
factory.setRepository(new File(file_path));// 设置文件存储位置
factory.setSizeThreshold(2048 * 1024);// 设置大小,如果文件小于设置大小的话,放入内存中,如果大于的话则放入磁盘中
ServletFileUpload upload = new ServletFileUpload(factory);
upload.setHeaderEncoding("utf-8");// 这里就是中文文件名处理的代码,其实只有一行
String fileName = "";
List list;
JSONObject jsonobj = new JSONObject();
try {
list = upload.parseRequest(request);
for (FileItem item : list) {
if (item.isFormField()) {
String name = item.getFieldName();
String value = item.getString("utf-8");
} else {
String name = item.getFieldName();
String value = item.getName();
fileName =name + ".jpg";
if (item.getSize() > 10485760) {//您好,上传文件要小于10M!
jsonobj.put("retCode","100");
jsonobj.put("retMsg","您好,上传文件要小于10M!"):
} else {//上传成功
item.write(new File(upload_file_path,fileName));
System.out.println(File.separator + "corpfile" + File.separator + fileName);
jsonobj.put("retCode","0");
jsonobj.put("retMsg","您好,上传成功!");
}
}
}
} catch (Exception e) {//上传失败
e.printstacktrace();
jsonobj.put("retCode","9999");       jsonobj.put("retMsg","您好,文件上传失败,");
}
return jsonobj;
}

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

原文地址:https://www.jb51.cc/ajax/46613.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐