文件上传下载——通过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了一下,抛给了上一层了。
- 文件上传下载——通过struts的FormFile上传单个excel文件
- 文件上传下载——通过ahxu扩展后的组件DiskFileUploadEx上传单个excel
- Struts FormFile 文件上传
- struts文件上传FormFile
- struts FormFile 上传文件
- 基于Struts FormFile上传文件
- 基于Struts FormFile上传文件
- 基于Struts FormFile上传文件
- 基于Struts FormFile上传文件—(转载于陈毓哲老师的博客)
- 利用struts的FormFile上传excel文件,并导入插入数据库
- 基于struts 的FormFile实现文件的上传功能
- 基于struts 的FormFile实现文件的上传功能
- struts中上传文件-FormFile应用
- struts中上传文件-FormFile应用
- struts中上传文件-FormFile应用
- struts中上传文件-FormFile应用
- struts单个文件上传
- 通过formFile实现上传文件,图片,或者其他,struts中继承action和dispatchAction的区别和用法
- Lniux和Windows下如何删除SVN版本信息?
- supesite后台增加菜单和功能
- U-Boot的环境变量
- 关于VS2010的调试信息即.pdb文件
- 修正Windows XP对文档内容搜索的支持问题
- 文件上传下载——通过struts的FormFile上传单个excel文件
- 第三天 二列和三列布局
- 关于Linux常用的二进制文件分析方法
- Linux常见瓶颈
- 高并发高负载的大型网站系统架构
- 正则表达式
- U-Boot的常用命令
- Kernel panic 信息分析方法
- Android动画开发——Animation显示隐藏菜单效果