jQuery实现异步上传一个或多个文件
本文实例为大家分享了jQuery实现异步上传一个或多个文件的具体代码,供大家参考,具体内容如下
首先使用SpringMvc文件上传,需要引入第三方上传文件的jar:
commons-fileupload commons-fileupload 1.3.1 commons-io commons-io 2.4
响应json需要导入的包:
com.fasterxml.jackson.core jackson-databind 2.9.0 com.fasterxml.jackson.core jackson-core 2.9.0 com.fasterxml.jackson.core jackson-annotations 2.9.0
接下来看jsp文件:
<%@pagecontentType="text/html;charset=UTF-8"language="java"%>首页 同步上传一个文件
异步上传一个文件
异步上传一个文件,且表单有其他数据
编 号:
账户名:
金 额:
异步上传多个文件,且表单有其他数据
编 号:
账户名:
金 额:
下面是controller:
@Controller @RequestMapping("/upload") publicclassFileController{ /** *同步文件一个上传和异步上传一个文件,共同使用这一个控制器方法 *@paramrequest *@paramupload *@return *@throwsIOException */ @RequestMapping(value="/testUpload",method=RequestMethod.POST) publicStringupload(HttpServletRequestrequest,MultipartFileupload)throwsIOException{ //获取文件的保存路径 Stringpath=request.getServletContext().getRealPath("/uploads"); //获取上传文件的名称 Stringfilename=upload.getOriginalFilename(); //获取随机字符串 Stringprefix=UUID.randomUUID().toString().replaceAll("-",""); filename=prefix+"_"+filename; //创建文件对象 Filefile=newFile(path); //判断路径是否存在,不存在则创建 if(!file.exists()){ file.mkdir(); } //上传文件 upload.transferTo(newFile(file,filename)); return"success"; } /** *异步文件上传和表单数据 *@paramrequest *@paramupload *@return *@throwsIOException */ @RequestMapping(value="/testUpload2",method=RequestMethod.POST) public@ResponseBodyAccountupload2(HttpServletRequestrequest,MultipartFileupload,Accountaccount)throwsIOException{ //获取文件的保存路径 Stringpath=request.getServletContext().getRealPath("/uploads"); //获取上传文件的名称 Stringfilename=upload.getOriginalFilename(); //获取随机字符串 Stringprefix=UUID.randomUUID().toString().replaceAll("-",""); filename=prefix+"_"+filename; //创建文件对象 Filefile=newFile(path); //判断路径是否存在,不存在则创建 if(!file.exists()){ file.mkdir(); } //上传文件 upload.transferTo(newFile(file,filename)); returnaccount; } /** *异步多个文件上传和表单数据 *@paramrequest *@paramupload采用数组接收 *@return *@throwsIOException */ @RequestMapping(value="/testUpload3",method=RequestMethod.POST) public@ResponseBodyAccountupload3(HttpServletRequestrequest,MultipartFile[]upload,Accountaccount)throwsIOException{ //获取文件的保存路径 Stringpath=request.getServletContext().getRealPath("/uploads"); //创建文件对象 Filefile=newFile(path); //判断路径是否存在,不存在则创建 if(!file.exists()){ file.mkdir(); } for(MultipartFilemultipartFile:upload){ //获取上传文件的名称 Stringfilename=multipartFile.getOriginalFilename(); //获取随机字符串 Stringprefix=UUID.randomUUID().toString().replaceAll("-",""); filename=prefix+"_"+filename; //上传文件 multipartFile.transferTo(newFile(file,filename)); } returnaccount; } }
publicclassAccountimplementsSerializable{ privateintid; privateStringname; privatefloatmoney; //getterorsetter.... }
注意事项:
上传文件时,表单的enctype修改为:multipart/form-data;
后端使用MultipartFileupload对象接收,upload必须和的name属性一致;
上传多个文件,给添加:multiple=“multiple”
效果:
更多精彩内容请参考专题《ajax上传技术汇总》,《javascript文件上传操作汇总》和《jQuery上传操作汇总》进行学习。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。