目的:实现发送邮件功能
背景:财务总监觉得网上那些工资条工具不安全,要求我写一个发送工资条的小程序嵌入到OA里面。具体实现就是导入Excel,发送到用户邮箱,不得存储在数据库
实现:遍历每个人的工资信息,按照邮箱发送工资条即可
逻辑:前台上传Excel,生成一个table,点击发送后遍历table,将数据传到后台,发送到对应邮箱,成功返回ok,记录发送成功数据,失败则记录失败数据序号
后端代码部分:
@ResponseBody
@RequestMapping(value="email")
public Map<String,String> email(SalarySheet salary){
Map<String, String> map = new HashMap<String,String>();
try {
SalarySheetController.send(salary);
map.put("success", "ok");
} catch (Exception e) {
map.put("success", "error");
e.printStackTrace();
}
return map;
}
// 发件人邮箱的 SMTP 服务器地址, 必须准确, 不同邮件服务器地址不同, 一般(只是一般, 绝非绝对)格式为: smtp.xxx.com
public static String myEmailSMTPHost = "smtp.exmail.qq.com";
public static void send(SalarySheet salary) throws Exception {
// 1. 创建参数配置, 用于连接邮件服务器的参数配置
Properties props = new Properties(); // 参数配置
props.setProperty("mail.transport.protocol", "smtp"); // 使用的协议(JavaMail规范要求)
props.setProperty("mail.smtp.host", myEmailSMTPHost); // 发件人的邮箱的 SMTP 服务器地址
props.setProperty("mail.smtp.auth", "true"); // 需要请求认证
// 2. 根据配置创建会话对象, 用于和邮件服务器交互
Session session = Session.getDefaultInstance(props);
session.setDebug(true); // 设置为debug模式, 可以查看详细的发送 log
// 3. 创建一封邮件
MimeMessage message = createMimeMessage(session, salary.getEmailName(),salary);
// 4. 根据 Session 获取邮件传输对象
Transport transport = session.getTransport();
// 5. 使用 邮箱账号 和 密码 连接邮件服务器, 这里认证的邮箱必须与 message 中的发件人邮箱一致, 否则报错
transport.connect(salary.getEmailName(), salary.getPassword());
// 6. 发送邮件, 发到所有的收件地址, message.getAllRecipients() 获取到的是在创建邮件对象时添加的所有收件人, 抄送人, 密送人
transport.sendMessage(message, message.getAllRecipients());
// 7. 关闭连接
transport.close();
}
/**
*
* @Title: createMimeMessage
* @Description: 创建邮件
* @author: WangFucheng
* @param session
* @param sendMail
* @param salary
* @return
* @throws Exception MimeMessage 返回类型
* @throws
*/
public static MimeMessage createMimeMessage(Session session, String sendMail,SalarySheet salary) throws Exception {
// 1. 创建一封邮件
MimeMessage message = new MimeMessage(session);
// 2. From: 发件人(昵称有广告嫌疑,避免被邮件服务器误认为是滥发广告以至返回失败,请修改昵称)
message.setFrom(new InternetAddress(sendMail, "工资条助手", "UTF-8"));
// 3. To: 收件人(可以增加多个收件人、抄送、密送)
message.setRecipient(MimeMessage.RecipientType.TO, new InternetAddress(salary.getEmail(), salary.getName(), "UTF-8"));
// 4. Subject: 邮件主题(标题有广告嫌疑,避免被邮件服务器误认为是滥发广告以至返回失败,请修改标题)
message.setSubject(salary.getTitle(), "UTF-8");
// 5. Content: 邮件正文(可以使用html标签)(内容有广告嫌疑,避免被邮件服务器误认为是滥发广告以至返回失败,请修改发送内容)
String html = "<table border='1'>"
+ "<tr>"
+"<th>部门</th>"
+"<th>职位</th>"
+"<th>姓名</th>"
+"<th>身份证号</th>"
+"<th>考勤天数</th>"
+"<th>工资</th>"
+"<th>养老、失业实际缴费工资数 </th>"
+"<th>医疗、工伤和生育实际缴费工资数</th>"
+"<th>公司缴纳养老险(19%)</th>"
+"<th>个人缴纳养老险(8%)</th>"
+"<th>公司缴纳失业险(0.8%)</th>"
+"<th>个人缴纳失业险(0.2%)</th>"
+"<th>公司缴纳工伤险(0.4%)</th>"
+"<th>公司缴纳生育险(0.8%)</th>"
+"<th>公司缴纳医疗险(10%)</th>"
+"<th>个人缴纳医疗险(2%+3)</th>"
+"<th>公司缴纳社保合计</th>"
+"<th>个人缴纳社保合计</th>"
+"<th>出差补助 </th>"
+"<th>电脑补助</th>"
+"<th>应发合计</th>"
+"<th>个人所得</th>"
+"<th>超出应纳税额</th>"
+"<th>应纳个人所得税</th>"
+"<th>实发工资</th>"
+"</tr>"
+"<tr>"
+"<td>"+salary.getOffice()+"</td>"
+"<td>"+salary.getPosition()+"</td>"
+"<td>"+salary.getName()+"</td>"
+"<td>"+salary.getId()+"</td>"
+"<td>"+salary.getAttendance()+"</td>"
+"<td>"+salary.getWage()+"</td>"
+"<td>"+salary.getInsuranceOneTwo()+"</td>"
+"<td>"+salary.getInsuranceThreeFourFive()+"</td>"
+"<td>"+salary.getCompanyInsuranceOne()+"</td>"
+"<td>"+salary.getPersonEndowmentOne()+"</td>"
+"<td>"+salary.getCompanyInsuranceTwo()+"</td>"
+"<td>"+salary.getPersonEndowmentTwo()+"</td>"
+"<td>"+salary.getCompanyInsuranceThree()+"</td>"
+"<td>"+salary.getCompanyInsuranceFour()+"</td>"
+"<td>"+salary.getCompanyInsuranceFive()+"</td>"
+"<td>"+salary.getPersonEndowmentFive()+"</td>"
+"<td>"+salary.getCompanyInsurance()+"</td>"
+"<td>"+salary.getPersonInsurance()+"</td>"
+"<td>"+salary.getTravelAllowance()+"</td>"
+"<td>"+salary.getComputerAllowance()+"</td>"
+"<td>"+salary.getShouldSend()+"</td>"
+"<td>"+salary.getPersonialIncome()+"</td>"
+"<td>"+salary.getBeyondTax()+"</td>"
+"<td>"+salary.getTax()+"</td>"
+"<td>"+salary.getRealWage()+"</td>"
+"</tr>"
+ "</table>";
message.setContent(html, "text/html;charset=UTF-8");
// 6. 设置发件时间
message.setSentDate(new Date());
// 7. 保存设置
message.saveChanges();
return message;
}
前台点击发送按钮后,后台获取对应的数据,配置参数,配置邮件,注意的是不同的邮箱配置信息是不一样的,我这儿使用的是腾讯的企业邮箱发送文件所以