`
lz726
  • 浏览: 335282 次
  • 性别: Icon_minigender_2
  • 来自: 福建,福州
社区版块
存档分类
最新评论

FormFiile实现的多个附件功能

阅读更多
今天上头不在,于是总结下做的一些东西.嘎嘎~
Form
  1. public class EmailForm  extends  ActionForm{                 
  2.     private   FormFile file;//附件,fileMap,value 是配合FormFile使用的   
  3.     private   Map    fileMap;   
  4.     private   Object  value; 
  5.   
  6.     public  EmailForm(){
         
         fileMap = new HashMap();  //构造函数里头初始化
        }
  7.     public FormFile getFile() {   
  8.         return file;   
  9.     }   
  10.     public void setFile(FormFile file) {   
  11.         this.file = file;   
  12.     }   
  13.   
  14.     public Map getFileMap() {   
  15.         return fileMap;   
  16.     }   
  17.     public void setFileMap(Map fileMap) {   
  18.         this.fileMap = fileMap;   
  19.     }   
  20.   
  21.     public void setValue(String attributeKey, Object attributeValue)   
  22.     {   
  23.         getFileMap().put(attributeKey, attributeValue);   
  24.     }   
  25.   
  26.     public Object getValue(String attributeKey)   
  27.     {   
  28.         Object keyValue = getFileMap().get(attributeKey);   
  29.   
  30.         return keyValue;   
  31.     }   
  32. }   

界面上的写法:file控件一定要写成这样~:

  1. <html:file property="value(file0'+upload_num+')" name="emailForm"/>  

具体实现的JS:

  1.   //添加附件   
  2. var upload_num=0   
  3. var card_type_handle;   
  4. var MAX_UPLOAD_NUMBER=8;   
  5. function add_upload()   
  6. {   
  7.  if (upload_num>=MAX_UPLOAD_NUMBER)   
  8. {   
  9.   alert('最多只能上传'+MAX_UPLOAD_NUMBER+'个文件');   
  10.   return ;   
  11. }   
  12. ++upload_num;   
  13. tr=document.all.tbl_upload.insertRow();   
  14. tr.insertCell().innerText="附件";   
  15. tr.style.backgroundColor='#ffffff';   
  16. str='
  17. tr.insertCell().innerHTML=str;   
  18. upload_num_view();   
  19. }   
  20. function delete_upload()   
  21. {   
  22. document.all.tbl_upload.deleteRow(window.event.srcElement.parentElement.parentElement.rowIndex);   
  23. upload_num--;   
  24. upload_num_view();   
  25. }   
  26. function upload_num_view()   
  27. {   
  28.   document.getElementById("upload_num_viewer").innerText=MAX_UPLOAD_NUMBER-upload_num;   
  29.   document.getElementById("acess").value=upload_num;   
  30. }  

html:两行布局:

  1. <tr>  
  2. <td colspan="7">  
  3. <input name="addAccessory" type="button" class="mybutton" style="cursor: hand;"    
  4. id="addAccessory" value="添加附件" onClick="add_upload();">  
  5. [提示:您能发送的邮件附件总容量最大为15M!(最多还能上传<span id='upload_num_viewer' style='color:red'>span><script>upload_num_view()script>  个)]   
  6. td>  
  7. tr>  
  8. <tr  id="accessory"><td colspan="7">  
  9. <table width="100%" border="0" id="tbl_upload">  
  10. table>    
  11. td>tr>  

 

java 代码:这里循环变量i的初始值为1,因为是邮件里头的附件处理
  1. // 附件处理   
  2.         String istr = request.getParameter("acess");   
  3.         if (istr != null) {   
  4.             for (int i = 1; i < Integer.parseInt(istr) + 1; i++) {   
  5.                 FormFile ffile = (FormFile) form.getValue("file0" + i);   
  6.                 String filename = ffile.getFileName();   
  7.                 filename = filename.substring(filename.lastIndexOf("\\") + 1);  
  8.                 try {  
  9.                     ByteArrayDataSource dataSource = new ByteArrayDataSource(  
  10.                             ffile.getInputStream(), null);  
  11.                     email.attach(dataSource, MimeUtility.encodeText(filename),  
  12.                             filename);  
  13.                 } catch (Exception e) {  
  14.                     System.out.println("附件处理错误:" + e);   
  15.                 }   
  16.             }   
  17.         }   
分享到:
评论

相关推荐

    航空公司客户满意度数据转换与预测分析Power BI案例研究

    内容概要:本文档介绍了航空公司的业务分析案例研究,涵盖两个主要部分:a) 使用SSIS进行数据转换,b) 利用RapidMiner进行预测分析。这两个任务旨在通过改善客户满意度来优化业务运营。数据来源包括多个CSV文件,如flight_1.csv、flight_2.csv、type.csv、customer.csv 和 address.csv。第一部分要求学生创建事实表、客户维度表和时间维度表,并描述整个数据转换流程。第二部分则需要利用RapidMiner开发两种不同的模型(如决策树和逻辑回归)来预测客户满意度,并完成详细的报告,其中包括执行摘要、预测分析过程、重要变量解释、分类结果、改进建议和伦理问题讨论。 适合人群:适用于对数据科学和商业分析有一定基础的学生或专业人士。 使用场景及目标:本案例研究用于教学和评估,帮助学员掌握数据转换和预测建模的技术方法,提高客户满意度和业务绩效。目标是通过实际操作加深对相关工具和技术的理解,并能够将其应用于实际业务中。 其他说明:此作业占总评的40%,截止时间为2024年10月25日16:00。

    课题设计-基于MATLAB平台的图像去雾处理+项目源码+文档说明+课题介绍+GUI界面

    一、课题介绍 现在我国尤其是北方城市,工业发达,废弃排放严重,这使得雾霾越来越厉害,让能见度极低。这严重影响了我们的交通系统,导航系统,卫星定位系统等,给人民出行,工作带来极大的不便利。目前市场上高清拍摄设备虽然可以让成像清晰点,但是造价高昂。如果有一套软件处理系统,可以实时地处理含雾的图像,让成像去雾化,让图像变得清晰,将会很受欢迎。 该课题是基于MATLAB平台的图像去雾处理,配备一个人机交互GUI界面,可以选择全局直方图均衡化,Retinex算法,同态滤波,通过对比处理前后的图像的直方图,而直方图是一副图像各灰度值在0-256的分布个数的表,信息论已经整明,具有均匀分布直方图的图像,其信息量是最大的。 二、算法介绍 ①全局直方图均衡化:通俗地理解就是,不管三七二十一,直接强行对彩色图像的R,G,B三通道颜色进行histeq均衡处理,然后进行三通道重组; ②Retinex算法:通俗地讲就是,分离R,G,B三通道,对每个通道进行卷积滤波。

    微信支付V2版本的支付接口,java的SDK

    微信支付V2版本的支付接口,java的SDK

    ide-eval-resetter-2.1.14 无限试用插件

    一款IDEA好用的插件,适用于旗舰版,可以延长试用期限,你懂的!

    电力系统继电保护整定及其应用-发电机组与变压器保护

    内容概要:本文详细介绍了发电机组保护整定方法,讨论了发电机可能遇到的故障状态及相应的保护措施,包括定子绕组故障、转子绕组故障、过电流、过电压等情况,并提供了具体的保护配置。接着,对变压器常见故障进行了分类说明,并给出变压器的主保护和后备保护配置方案。文章进一步计算了不同短路点的短路电流,阐述了互感器的选择标准,并举例解释了纵联保护的应用和后备保护的作用。 适合人群:电力系统工程师、继电保护技术人员及相关研究领域的学者。 使用场景及目标:适用于发电厂和变电站的设计、维护和运行人员,旨在提高电力系统的安全性和稳定性。目标是确保电力系统关键设备的安全运行,防止故障的发生,减少事故造成的损失。 其他说明:本文不仅提供了详细的理论分析,还包括了大量的数据计算和实例说明,有助于读者更好地理解和掌握继电保护的相关知识和技术。

    基于C++开发的微商系统项目源码.zip

    基于C++开发的微商系统项目源码 使用技术:C++/Qt、Mysql、TCP/IP 软件架构 三个大端:服务端、客户端(买家端)、业务端(卖家端) PS:需要连Mysql数据库才能正常使用,连接mysql时记得把用户、密码啥的改为自己的数据库信息

    1503ANDH1503002016_20241116222825

    1503ANDH1503002016_20241116222825

    数理逻辑近世代数复习资料,思维导图部分

    数理逻辑近世代数复习资料,思维导图部分

    京东中台业务架构敏捷性方法 MotriDSP 落地实践.pdf

    京东中台业务架构敏捷性方法 MotriDSP 落地实践.pdf

    毕业设计&课设_电影推荐系统项目:Spring Boot 开发,含多种技术,有前端地址,提供开发及部署说明.zip

    该资源内项目源码是个人的课程设计、毕业设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过严格测试运行成功才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。

    CCF会员复习资料(1).zip

    CCF会员复习资料(1).zip

    C#ASP.NET养老院老人信息管理系统源码数据库 SQL2008源码类型 WebForm

    ASP.NET养老院老人信息管理系统源码 这是一款非常优秀的养老院老人信息管理系统。程序功能齐全,可选择性强。 管理员后台: 1、人员信息管理:老人信息管理、管理员信息管理、员工信息管理 2、公寓信息管理:添加公寓楼信息、管理公寓楼信息、添加公寓信息、管理公寓信息 3、公寓安排管理:添加公寓安排、公寓安排管理、缴费管理 4、健康管理信息管理:添加健康管理信息、管理健康管理信息 5、紧急联络人管理 6、意见信息管理 7、公告信息管理:添加公告信息、管理公告信息 8、出入信息管理:请假信息管理、访客记录管理、退住情况 员工后台: 1、人员信息管理:老人信息管理 2、健康管理信息管理:管理健康管理信息 3、紧急联络人管理 4、意见信息管理 5、公告信息管理:管理公告信息 6、出入信息管理:请假信息管理、访客记录管理、退住情况 老人后台: 1、修改个人信息 2、修改登陆密码 3、意见信息管理:发布意见信息、意见信息管理 4、查看公告信息

    走向现代化数据分析架构:趋势与挑战.pdf

    走向现代化数据分析架构:趋势与挑战.pdf

    PHP通用权限管理系统源码数据库 MySQL源码类型 WebForm

    PHP通用权限管理系统源码 安装说明: 1.把管理系统.sql 导入到MYSQL数据库中,把App/Common/Conf/db.php中的数据库名称,账号密码改成自己的。 2.把程序放在二级目录下,如:http://localhost/xcrm/ 账号 admin 密码admin123 3.请使用IE8以上,或是谷歌浏览器。 4.支持环境php+apache,php版本要大于5.3 注意:删除App下面 Runtime 文件夹;如果Linux服务器,需要分配777权限; 修改config.php数据库连接地址:绝对路径 大家在安装的时候遇到问题 1.页面顶部出现空白一行 解决办法:db.php 要以uft8无BOM格式编码 保存 notepad++ 编辑器里 格式 下 2.乱码问题 解决办法:数据库建表的时候选 uft8-general-ci 编码格式 然后点开 SQL 把1,SQL复制进去,执行就可以了 3、如果程序执行时报错? 解决办法:保存PHP>5.3版本 删除App下面 Runtime 文件夹 使用须知:注释:权限管理,修改完用户所属组之后,

    各省电商指数数据(1990-2022).xlsx

    详细介绍及样例数据:https://blog.csdn.net/m0_65541699/article/details/143823092

    会议席卡制作模版,电子表格,方便实用

    席卡制作模版会议较多的单位,经常要打印席卡,本模版可以解决燃眉之急

    从 0 到 1 构建集群服务质量运营体系降低云成本.pdf

    从 0 到 1 构建集群服务质量运营体系降低云成本.pdf

    永辉超市的混合云建设与运维.pdf

    永辉超市的混合云建设与运维.pdf

    java超市订单管理系统源码数据库 MySQL源码类型 WebForm

    Java超市订单管理系统源码 运行环境:jdk8(jdk7)+mysql+Eclipse+maven+tomcat7 项目技术:springboot+spring mvc+mybatis+jquery+jsp 注意事项:1.所有模块没有实现查看,编辑,删除,添加功能 2.压缩包中的建库smbms.sql是mysql5.7的语句,其中datetime比较特殊,在低版本mysql下会报错

    基于MATLAB语言的支持向量机(svm)分类算法的机器视觉程序,里面包含训练数据集和MATLAB源码下载即可运行,可做毕业设计

    基于MATLAB语言的支持向量机(svm)分类算法的机器视觉程序,里面包含训练数据集和MATLAB源码,下载即可运行,可做毕业设计。

Global site tag (gtag.js) - Google Analytics