文件上传下载——通过struts的FormFile上传单个excel文件

来源:互联网 发布:龙葵碱 知乎 编辑:程序博客网 时间:2024/05/29 13:43

通过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了一下,抛给了上一层了。