一:今天在使用struts2做文件上傳時出現了該異常:
警告: Unable to parse request
org.apache.commons.fileupload.FileUploadBase$SizeLimitExceededException: the request was rejected because its size (5897994) exceeds the configured maximum (2097152)at org.apache.commons.fileupload.FileUploadBase$FileItemIteratorImpl.<init>(FileUploadBase.java:937)at org.apache.commons.fileupload.FileUploadBase.getItemIterator(FileUploadBase.java:331)at org.apache.commons.fileupload.FileUploadBase.parseRequest(FileUploadBase.java:351)at org.apache.struts2.dispatcher.multipart.JakartaMultiPartRequest.parseRequest(JakartaMultiPartRequest.java:151)at org.apache.struts2.dispatcher.multipart.JakartaMultiPartRequest.processUpload(JakartaMultiPartRequest.java:90)at org.apache.struts2.dispatcher.multipart.JakartaMultiPartRequest.parse(JakartaMultiPartRequest.java:80)at org.apache.struts2.dispatcher.multipart.MultiPartRequestWrapper.<init>(MultiPartRequestWrapper.java:75)at org.apache.struts2.dispatcher.Dispatcher.wrapRequest(Dispatcher.java:753)at org.apache.struts2.dispatcher.ng.PrepareOperations.wrapRequest(PrepareOperations.java:140)at org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.doFilter(StrutsPrepareAndExecuteFilter.java:83)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103)at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293)at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:861)at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:606)at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)at java.lang.Thread.run(Unknown Source)
2014-7-31 22:53:04 com.opensymphony.xwork2.util.logging.commons.CommonsLogger warn
警告: the request was rejected because its size (5897994) exceeds the configured maximum (2097152)
為什么會出現這個錯誤?
查看struts.properties中有這么一句struts.multipart.parser=Jakarta,實際上這一句也可以不寫因為這是struts2為了支持文件上傳默認的。那么這個Jakarta到底是什么東西呢?實際上Jakarta實際上就是org.apache.struts2.dispatcher.multipart.JakartaMultiPartRequest類。打開JakartaMultiPartRequest.java的源代碼你會發現這個類實現了MultiPartRequest接口,在這個類封裝了對底層ServletFileUpload的操作,由于common-fileupload組件默認最大支持上傳文件的大小為2M,當我們上傳大于2M的文件時,就會出現上面的異常。是這個異常的發生導致了fileUpload攔截器沒有機會執行,所以看到的是頁面沒有任何變化,也沒有任何提示信息,只是在控制臺打印出了上面的異常。解決的辦法在struts.properties文件中把struts.multipart.maxSize設置成一個比較大的值,也是就說maxSize遠遠要大于可能上傳文件的大小和fileUpload攔截器中maxinumSize的值。 如可以配置:struts.multipart.maxSize=10000000 即可。
默認的在struts中的default.properties中有這句話:struts.multipart.maxSize=2097152 將上傳文件限制為2MB
我的配置是:在struts.xml中加入<constant name="struts.multipart.maxSize" value="524288000" />將默認的上傳文件最大值變成500MB
Web容器啟動的時候加載文件的時候先加載default.properties,然后再加載struts.xml配置文件。