悲剧的一个BUG····STRUTS2 上传 问题。
-------------------------
搞了大半天,总是奇怪问题的现象,最后附录自己的思考过程。
---------------------------------------
现象:
由于当用户在上传文件的时候,由于文件在上传过程中流还没传送完毕结果客户端就断开了链接(可能耗时比较久,造成浏览器假死的状态,然后用户强制关闭了浏览器的进程),导致上传组件抛出异常,而且这个异常在关闭上传页面之后再打开的时候还是存在,引起上传的功能点崩溃。
----------------------分析-------------------
原因分析:
原先使用 struts2 自带的common-fileupload 组件上传文件。
当文件上传出错时(包括强行关闭浏览器导致的流关闭错误),会产生actionerror对象 。
在进入Action之前 会 经过 validate 方法,
validate 方法 检测到 actionerror 后,会直接转向input页面,导致错误信息一直出现,从而导致上传组件不可用。只能通过服务器重启来解决。
(PS:spring 配置的action是单列)
---------STRUTS2源码--------
源码大家自己去看吧。
大概流程就是
FilterDispatcher--->Dispatcher--->MultiPartRequestWrapper
然后交由Apache的commons-fileupload组件来解析了。
在MultiPartRequestWrapper的构造方法中,会调用MultiPartRequest(默认为JakartaMultiPartRequest类)的parse方法来解析请求。
--------------------------------------------------------------
解决方案如下:
1. 覆盖组件中的JakartaMultiPartRequest方法,丢弃error对象。
(据说还诡异的出现问题。)
2. 修改action类,重写validate ()方法,清除ErrorsAndMessages 。
action中:
//重写validate()方法,去除error
public void validate(){
this.clearErrorsAndMessages();
}
3. 更换组件。采用smartupload组件(但是这个组件对大文件上传存在着内存溢出的问题,只支持到100M 左右)
所以妥妥的 方案2.。。。。。。。。。。。