MultipartFile文件上传后台报错request is not a multipart request

朱雀 2020-10-17 07:55 1056阅读 0赞

日常开发中经常会用到MultipartFile文件上传的功能

1.直接使用表单提交的方式

前端:

  1. <form action="http://xxx.xx.xx/page" method="post" enctype="multipart/form-data">
  2. 选择文件:<input type="file" name="apkFile">
  3. <input type="text" name="type" value = "2">
  4. <input type="submit" value="提交">
  5. </form>

后台:

  1. public Response page(MultipartFile apkFile,String type,
  2. HttpServletRequest request,HttpServletResponse response){}

注意:(1)必须是POST请求 (2)form上必须声明 enctype=”multipart/form-data”

使用form提交的时候,你的apkFile是会自动提交上去的,就算没有选择文件,也会上传一个空文件夹过去

2.使用ajax方式

前端:

  1. 选择文件:<input type="file" id="fileInput" name="apkFile">
  2. $.ajax({
  3. type: 'POST',
  4. url: url,
  5. data: params,//你要传递的参数,包括要上传的文件(如:$("#fileInput")[0].files[0])
  6. dataType: 'json',
  7. success: success,
  8. error: fail,
  9. complete: after
  10. });

后台:

  1. public Response page(String type,
  2. HttpServletRequest request,HttpServletResponse response){
  3. String contentType = request.getContentType();//通过request获取请求类型
  4. if (contentType != null && contentType.toLowerCase().startsWith("multipart/")) {//如果请求类型为multipart,获取里面的文件信息
  5. MultipartHttpServletRequest multipartRequest =
  6. WebUtils.getNativeRequest(request, MultipartHttpServletRequest.class);
  7. return multipartRequest.getFile(fileName); //返回前端传递的文件信息
  8. }else{
  9. return null;
  10. }
  11. }

注意:(1)必须是POST请求 (2)form上必须声明 enctype=”multipart/form-data”

(3)后台的方法里面不能写MultipartFile参数

使用ajax上传的时候,因为ajax是不能直接传递文件类型参数的,所以如果直接在后台方法里面写MultipartFile参数,当你没有上传文件的时候回直接提示request is not a multipart request(请求类型不是一个multipart请求),所以使用ajax方式的话就只能从request里面取获取你要上传的东西。

如果是多文件上传的话,要么在参数里面使用MultipartFile[]去接收,要么就是request里面去接收,使用MultipartHttpServletRequest.getFiles()方法就可以的到一个List

PS:两种方式用起来感觉差不多,望采纳!本人刚入行的小白,遇到这个问题也是搞了大半天才搞出来的,所以这里与大家分享一下,如果有什么说的不对的,欢迎补充哈。。。。。。

发表评论

表情:
评论列表 (有 0 条评论,1056人围观)

还没有评论,来说两句吧...

相关阅读