springmvc+ajax+formdata上传图片代码实例
2019-09-02 14:58
1181 查看
最近工作涉及到了上传图片的情况,在网上看了很多,就着重学习了下。上传文件的方式有多种,这里对使用FormData的方式进行说明。
1、springmvc项目想要上传文件,需要使用multipart方式,所以在spring-mvc.xml配置文件中需要增加multipart相关配置,代码如下
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <!-- one of the properties available; the maximum file size in bytes --> <property name="maxUploadSize" value="50000000"/> </bean>
2、jsp代码
<form action="picUpload" method="post" enctype="multipart/form-data" id="fileForm"> <input type="file" id="pic" name="pic" multiple><br><br> <input type="text" id="id" name="id"><br><br> <input type="text" id="name" name="name"><br><br> <input type="button" value="上传" onclick="morePicUpload()"> </form>
需要注意的是,form 的 enctype 值必须为 multipart/form-data,这样才能在提交表单的时候传递文件数据。
如果要一次选择多个文件,可以在file表单添加"multiple",这样在选择文件时可以一次选择多个文件。
3、js代码
function morePicUpload(){ var formData = new FormData(document.getElementById("fileForm")); alert(0); $.ajax({ url : basePath+"morePicUpload", type : "post", data :formData, async : false, cache : false, dataType : "json", contentType : false, processData : false, success : function(data){ //code } }); }
先创建formData,用来存放表单中的内容,"fileForm"为jsp页面中form的id。
4、最后的是controller,代码如下
@RequestMapping("/morePicUpload") @ResponseBody public ResultTo morePicUpload(HttpServletRequest request){ ResultTo resultTo = new ResultTo(); resultTo.setData(""); MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request; String id = multipartRequest.getParameter("id"); String name = multipartRequest.getParameter("name"); System.out.println(id); System.out.println(name); List<MultipartFile> filelist = multipartRequest.getFiles("pic"); for(MultipartFile file:filelist){ if(!file.isEmpty()){ System.out.println(file.getOriginalFilename()); } } return resultTo; }
使用"MultipartHttpServletRequest"可以获取form表单中的所有空间内容,文件可以通过"List<MultipartFile> filelist = multipartRequest.getFiles("pic");"方式获取,然后进行文件的上传等操作就行了。
以上就是本文的全部内容,希望对大家的学习有所帮助
您可能感兴趣的文章:
相关文章推荐
- SpringMVC+Ajax用FormData对象上传页面的图片(文件),并且立马在页面上显示出来
- 使用html+ajax+formdata+SpringMVC实现单个文件,和多个文件上传功能
- 使用html+ajax+formdata+SpringMVC实现单个文件,和多个文件上传功能
- SpringMVC+Ajax实现文件批量上传和下载功能实例代码
- 使用FormData进行Ajax请求上传文件的实例代码
- 通过formdata ajax上传图片 以及后台接收formdata数据 mvc
- Spring Boot实现图片上传/加水印一把梭操作实例代码
- swfupload ajax无刷新上传图片实例代码
- 通过formdata ajax上传图片 以及后台接收formdata数据 mvc
- ajax 请求后台数据(及使用FormData对象提交表单及上传图片)
- springmvc + ajaxfileupload 实现异步上传文件(图片)
- Ajax提交Form表单及文件上传的实例代码
- springmvc + ajaxfileupload 实现异步上传文件(图片)
- freemarker+springMVC+ajaxfileupload实现异步图片上传(多张)
- nodejs利用ajax实现网页无刷新上传图片实例代码
- Spring利用MultipartFile接收FormData对象上传文件(可接收AJAX上传的包含多文件的复杂表单内容)
- SpringMVC+ajaxFileUpload上传图片 IE浏览器弹下载框问题解决方案
- swfupload ajax无刷新上传图片实例代码
- maven+myeclise+springmvc+jersey+ajax实现图片跨服务器上传
- ajaxfileupload.js+springMVC实现多个图片与数据同一个ajax方法上传