通过struts的FormFile上传单个excel文件
思路:
1、通过struts的FormFile获取File(这个文件的路径是“客户端的选择的路径地址”)
2、将客户端的文件,以流的形式,存放到服务器端指定的目录
3、读取服务器端的excel文件,先获取工作簿workbook,然后获取这个工作簿的sheet,然后获取sheet中的每一行
4、校验: (1)、将sheet中的数据,按行读取,并插入到临时表中
(2)、针对这次导入数据,按列校验——每一列一个select,查出不符合规则的id
(3)、如果校验不通过,针对同一个错误,返回一批id,通过request返回到页面
(4)、如果校验都通过,将临时表中的数据拷贝到正式表,清空临时表,将正式表的数据封装成对象返回
jsp页面:
<td colspan="2">
<html:file property="theFile" size="10" />
</td>
<td>
<a onClick="if(document.all('theFile').value!='') uploadAndCheck();"class="butlink">
<span class="but2"> 上传 </span>
</a>
</td>
function uploadAndCheck(){
orgStaffChangeForm.action=orgStaffChangeForm.action;
setMethodAndNoConfirm('uploadAndCheck');
}
后台方法:
注意事项:
1、FormFile是struts包对外的一个接口,而且org.apache.struts.upload包是使用的commons-fileupload-1.0进行的封装。
FormFile的实现依然使用commons-fileupload-1.0版本的DiskFileUpload类。
DiskFileUpload这个类,commons-fileupload已经弃用了,取而代之的是ServletFileUpload类了
2、如果使用了它来实现文件上传的功能,则必须是FormFile对象在被初始化以后才能使用,它在进入Action之前就已经初始化好了!
3、struts是默认使用org.apache.struts.upload.CommonsMultipartRequestHandler类来处理FormFile指定的上传文件的。
4、 Struts根本没有把上传过程中出的超出最大值的异常带到Action,因为那是不可能的,而是把它放到了rquest的Attribute里。
而出了其他异常如enctype不对,磁盘空间不足怎么办?很遗憾,Struts没有去处理它,而是log了一下,抛给了上一层了。