java封装发送邮件的插件_java利用commons-email发送邮件并进行封装

packagecom.example.demo.email;importorg.apache.commons.mail.EmailAttachment;importorg.apache.commons.mail.EmailException;importorg.apache.commons.mail.HtmlEmail;importjava.util.List;/*** Created by 敲代码的卡卡罗特 on 2018/3/29.*/

public classMailUtil {//邮箱

private static String mailServerHost = "smtp.163.com";private static String mailSenderAddress = "15515664xxx@163.com";private static String mailSenderNick = "敲代码的卡卡罗特";private static String mailSenderUsername = "15515664xxx@163.com";private static String mailSenderPassword = "xxxxx";/*** 发送 邮件方法 (Html格式,支持附件)

*

*@returnvoid*/

public static voidsendEmail(MailInfo mailInfo) {try{

HtmlEmail email= newHtmlEmail();//配置信息

email.setHostName(mailServerHost);

email.setFrom(mailSenderAddress,mailSenderNick);

email.setAuthentication(mailSenderUsername,mailSenderPassword);

email.setCharset("UTF-8");

email.setSubject(mailInfo.getSubject());

email.setHtmlMsg(mailInfo.getContent());//添加附件

List attachments =mailInfo.getAttachments();if (null != attachments && attachments.size() > 0) {for (int i = 0; i < attachments.size(); i++) {

email.attach(attachments.get(i));

}

}//收件人

List toAddress =mailInfo.getToAddress();if (null != toAddress && toAddress.size() > 0) {for (int i = 0; i < toAddress.size(); i++) {

email.addTo(toAddress.get(i));

}

}//抄送人

List ccAddress =mailInfo.getCcAddress();if (null != ccAddress && ccAddress.size() > 0) {for (int i = 0; i < ccAddress.size(); i++) {

email.addCc(ccAddress.get(i));

}

}//邮件模板 密送人

List bccAddress =mailInfo.getBccAddress();if (null != bccAddress && bccAddress.size() > 0) {for (int i = 0; i < bccAddress.size(); i++) {

email.addBcc(ccAddress.get(i));

}

}

email.send();

System.out.println("邮件发送成功!");

}catch(EmailException e) {

e.printStackTrace();

}

}

}

请移步:http://download.csdn.net/source/2881508 这是个封装java使用的 web插件报表,这个市面上已经存在,但是是个商业报表: 本人提供的是免费报表,不不敢与商家争长短,但求对你有用: 使用方法: 范例使用的是access数据库,首先在odbc 注册ReportDemo.mdb 数据源,名字随你喜好, 然后修改classes文件下的 db.properties 的连接。 然后把项目放在tomcat下运行既可: 起作用的关键文件:RMVIEWP.CAB 文件,客户端插件 Lib下的两个包:RMVIEW.jar,commons-logging.jar 使用接口: package common.rmview; /* * 设计的第一步,首先定义字段的类型, * 然后通过AddRow将结果加入缓存中 * */ import common.rmview.surperInterface.IDataSet; import common.rmview.until.Types; public interface IRMDataSet extends IDataSet { public void addField(String fieldName, Types.filedType type, int fieldLength, Boolean isNull);//1:将段类型加入 public void addField(String fieldName, Types type, int fieldLength);//1:将段类型加入,isNull 默认为 false public void AddRow(IRMDataRecord rmd);//2:在 IRMDataRecord实现类赋值完成一条记录后使用一次,循环加入. } package common.rmview; import common.rmview.surperInterface.IDataRecord; /* * 使用时的第二步 * 通过这个接口设置结果集 */ public interface IRMDataRecord extends IDataRecord { public void SetValue(String fieldName,Object objValue); } package common.rmview; /* * 第三步: * 前面IDataSet,IRMDataRecord实现类完成后,通过此接口的实现类向html也面输出ie到ie以方便ocx的取值使用 */ public interface IRMEngine { final int rmf=1; final int rls=2; public void SetReportFile(String urlandFileName,int fileFormat);//1:设置报表路径及文件名称 public void AddClientDataSet(String dataSourceName,IRMDataSet rmd);//2:设置数据源名称以ocx使用,并把IRMDataSet实现的结果加入 /* * 字符串组装方式:rm报表报表文件流base64码+"&&"+字段类型码+"&&"+结果集+"&&"+数据源名称 */ public String CreateViewer();//3:生成在html页面的编码 } 具体的使用方法请参照 index.jsp 报表的使用方法请自己参照官方的文档 RMDesigner.exe 是个设计器,也可以使用delphi 的RM报表来设计 使用没有任何的限制。使用前多测试,看是否真正是你需要的。 有疑问请发邮件到 lujianfu123@yahoo.com.cn 修正版本地址:http://download.csdn.net/source/1427608
http://download.csdn.net/source/1856731 (最新) 这是个封装java使用的 web插件报表,这个市场上已经存在,但是是个商业报表: 本人提供的是免费报表,不不敢与商家争长短,但系希望对你有用: 使用方法: 范例使用的是access数据库,首先在odbc 注册ReportDemo.mdb 数据源,名字随你喜好, 然后修改classes文件下的 db.properties 的连接。 然后把项目放在tomcat下运行既可: 起作用的关键文件:RMVIEWP.CAB 文件,客户端插件 Lib下的两个包:RMVIEW.jar,commons-logging.jar 使用接口: package common.rmview; /* * 设计的第一步,首先定义字段的类型, * 然后通过AddRow将结果加入缓存中 * */ import common.rmview.surperInterface.IDataSet; import common.rmview.until.Types; public interface IRMDataSet extends IDataSet { public void addField(String fieldName, Types.filedType type, int fieldLength, Boolean isNull);//1:将段类型加入 public void addField(String fieldName, Types type, int fieldLength);//1:将段类型加入,isNull 默认为 false public void AddRow(IRMDataRecord rmd);//2:在 IRMDataRecord实现类赋值完成一条记录后使用一次,循环加入. } package common.rmview; import common.rmview.surperInterface.IDataRecord; /* * 使用时的第二步 * 通过这个接口设置结果集 */ public interface IRMDataRecord extends IDataRecord { public void SetValue(String fieldName,Object objValue); } package common.rmview; /* * 第三步: * 前面IDataSet,IRMDataRecord实现类完成后,通过此接口的实现类向html也面输出ie到ie以方便ocx的取值使用 */ public interface IRMEngine { final int rmf=1; final int rls=2; public void SetReportFile(String urlandFileName,int fileFormat);//1:设置报表路径及文件名称 public void AddClientDataSet(String dataSourceName,IRMDataSet rmd);//2:设置数据源名称以ocx使用,并把IRMDataSet实现的结果加入 /* * 字符串组装方式:rm报表报表文件流base64码+"&&"+字段类型码+"&&"+结果集+"&&"+数据源名称 */ public String CreateViewer();//3:生成在html页面的编码 } 具体的使用方法请参照 index.jsp 报表的使用方法请自己参照官方的文档 RMDesigner.exe 是个设计器,也可以使用delphi 的RM报表来设计 使用没有任何的限制。使用前多测试,看是否真正是你需要的。 修正:增加支持多数据源,报表显示完成内存化,本地不存任何的数据 新建QQ群:29672297 有疑问请发邮件到 lujianfu123@yahoo.com.cn
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值