解決SpringBoot中MultipartResolver和ServletFileUpload的沖突問題
MultipartResolver和ServletFileUpload沖突
如果同時使用了MultipartResolver 和ServletFileUpload,就會在iter.hasNext()返回false.然后整個循環(huán)就跳出去了。
整個問題產(chǎn)生的原因是Spring框架先調用了MultipartResolver 來處理http multi-part的請求。這里http multipart的請求已經(jīng)消耗掉。后面又交給ServletFileUpload ,那么ServletFileUpload 就獲取不到相應的multi-part請求。
1.首先spring boot默認會調用MultipartResolver
來處理http multi-part的請求,須在配置文件中把spring.http.multipart.enabled=false。這樣就不會默認調用MultipartResolver。

2.需要重寫一個MyMultipartResolver
重寫isMultipart方法
package dc.platform.admin.common.config;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.multipart.commons.CommonsMultipartResolver;
import javax.servlet.http.HttpServletRequest;
@Configuration
public class MyMultipartResolver extends CommonsMultipartResolver {
/**
* 這里是處理Multipart http的方法。如果這個返回值為true,那么Multipart http body就會MyMultipartResolver 消耗掉.如果這里返回false
* 那么就會交給后面的自己寫的處理函數(shù)處理例如剛才ServletFileUpload 所在的函數(shù)
* @see org.springframework.web.multipart.commons.CommonsMultipartResolver#isMultipart(javax.servlet.http.HttpServletRequest)
*/
@Override
public boolean isMultipart(HttpServletRequest request) {
// 過濾金格生成文書保存的接口 兼容MultipartResolver 或者 ServletFileUpload
if (request.getRequestURI().contains("mgt/document/upload")||request.getRequestURI().contains("/modules/document.html")) {
return false;
}
return super.isMultipart(request);
}
}
springMVC文件上傳時出現(xiàn)的“坑”—multipartResolver
首先,頁面代碼,這里是upload.jsp:
<form action="${pageContext.request.contextPath}/upload" method="post" enctype="multipart/form-data">
姓名:<input type="text" name="name">
文件:<input type="file" name="multipartFile">
提交: <input type="submit" value="提交">
</form>
然后,我們在pom文件中添加文件上傳用到的依賴文件:
<!--文件上傳依賴--> <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.3.3</version> </dependency> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.6</version> </dependency>
接著我們在spring-mvc.xml文件中配置文件上傳解析器:
<bean id="commonsMultipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <!--上傳文件總大小--> <property name="maxUploadSize" value="54280"/> <!--編碼方式--> <property name="defaultEncoding" value="UTF-8"/> <!--單個上傳的文件大小--> <property name="maxUploadSizePerFile" value="54280"/> </bean>
之后編寫了文件上傳代碼:
@RequestMapping("/upload")
@ResponseBody
public void upload(String name, MultipartFile multipartFile) throws IOException {
System.out.println(name);
String filename = multipartFile.getOriginalFilename();
multipartFile.transferTo(new File("F:\\"+filename));
}
這個時候你以為萬事大吉,可以成功運行的時候,驚喜出現(xiàn)了,頁面給你來一個500…

idea控制臺給你來個null

我把代碼從頭順了一遍始終沒找到我的錯,于是乎,有技術朋友是真好?。?!原來在文件解析器那里ID必須要配置為
multipartResolver
*哈哈,加粗是為了醒目~~~~*
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <!--上傳文件總大小--> <property name="maxUploadSize" value="54280"/> <!--編碼方式--> <property name="defaultEncoding" value="UTF-8"/> <!--單個上傳的文件大小--> <property name="maxUploadSizePerFile" value="54280"/> </bean>
大家千萬記得這個!
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
介紹下Java Spring的核心接口,容器中Bean的實例化
這篇文章主要介紹了Spring核心接口,容器中bean的實例化過程解析及完整代碼示例,簡單分析實例化bean過程并且分享了相關實例,具有一定借鑒價值,需要的朋友可以參考下2021-09-09
Java concurrency之CountDownLatch原理和示例_動力節(jié)點Java學院整理
CountDownLatch是一個同步輔助類,在完成一組正在其他線程中執(zhí)行的操作之前,它允許一個或多個線程一直等待。 下面通過本文給大家分享Java concurrency之CountDownLatch原理和示例,需要的的朋友參考下吧2017-06-06
Mybatis?大數(shù)據(jù)量批量寫優(yōu)化的案例詳解
這篇文章主要介紹了Mybatis?大數(shù)據(jù)量批量寫優(yōu)化的示例代碼,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-05-05
spring?Cloud微服務阿里開源TTL身份信息的線程間復用
這篇文章主要為大家介紹了spring?Cloud微服務中使用阿里開源TTL身份信息的線程間復用,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-01-01

