spring boot 邮件发送(带附件)
首先开启QQ邮箱的POP.SMTP服务器,获取授权码。
设置-->账户-->POP3/IMAP/SMTP/Exchange/CardDAV/CalDAV服务
pom.xml需要加载三个jar,可以在这个网站里下载:https://mvnrepository.com/
html页面
<form action="/send" method="post" enctype="multipart/form-data">
<table >
<tr>
<td>收件人</td>
<td><input type="text" name="addressee" size="50"> </td>
</tr>
<tr>
<td>主题</td>
<td><input type="text" name="title" size="50"> </td>
</tr>
<tr>
<td>添加附件</td>
<td><input type="file" name="file" size="50" accept=".doc"> </td>
</tr>
<tr>
<td>正文</td>
<td><textarea type="text" name="context" > </textarea></td>
</tr>
<tr>
<td ><input type="submit" value="发送" ></td>
</tr>
</table>
</form>
后台
package com.nenu.controller; import java.io.File;
import java.util.Date;
import java.util.Properties; import javax.activation.DataHandler;
import javax.activation.FileDataSource;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeBodyPart;
import javax.mail.internet.MimeMessage;
import javax.mail.internet.MimeMessage.RecipientType;
import javax.mail.internet.MimeMultipart;
import javax.mail.internet.MimeUtility;
import javax.servlet.http.HttpServletRequest; import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.multipart.MultipartFile; @Controller
public class SendController {
@RequestMapping(value="index")
public String show() {
return "index";
}
@RequestMapping(value="send",method=RequestMethod.POST)
public String send(HttpServletRequest request,@RequestParam(value = "file")MultipartFile file) throws Exception {
String fileName = file.getOriginalFilename();
File uploadDir = new File("D:\\txt");
// 创建一个目录 (它的路径名由当前 File 对象指定,包括任一必须的父路径。)
if (!uploadDir.exists())
uploadDir.mkdirs();
String path = "D:\\txt\\" + fileName;
// 新建一个文件
File tempFile = new File(path);
try {
// 将上传的文件写入新建的文件中
file.transferTo(tempFile);
} catch (Exception e) {
e.printStackTrace();
} String addressee = request.getParameter("addressee");
String context = request.getParameter("context");
String title = request.getParameter("title"); // 发件人的 邮箱 和 密码(替换为自己的邮箱和密码)
String myEmailAccount = "2813412434@qq.com";
String myEmailPassword = "lvkshxpdjlukdgii";
// 收件人邮箱(替换为自己知道的有效邮箱)
String receiveMailAccount = addressee; // 1. 创建参数配置, 用于连接邮件服务器的参数配置
Properties props = new Properties(); // 参数配置
props.setProperty("mail.transport.protocol", "smtp"); // 使用的协议(JavaMail规范要求)
props.setProperty("mail.smtp.host", "smtp.qq.com"); // 发件人的邮箱的 SMTP 服务器地址
props.setProperty("mail.smtp.port", "465");// 端口号
props.setProperty("mail.smtp.auth", "true");
props.setProperty("mail.smtp.ssl.enable", "true"); // 开启 SSL 连接, // 2. 根据配置创建会话对象, 用于和邮件服务器交互
Session session = Session.getInstance(props);
session.setDebug(true); // 设置为debug模式, 可以查看详细的发送 log // 3. 创建一封邮件
MimeMessage message = createMimeMessage(session, myEmailAccount, receiveMailAccount,title,path,context);
// 也可以保持到本地查看
// message.writeTo(file_out_put_stream); // 4. 根据 Session 获取邮件传输对象
Transport transport = session.getTransport(); // 5. 使用 邮箱账号 和 授权码 连接邮件服务器
transport.connect(myEmailAccount, myEmailPassword); // 6. 发送邮件, 发到所有的收件地址, message.getAllRecipients() 获取到的是在创建邮件对象时添加的所有收件人, 抄送人, 密送人
transport.sendMessage(message, message.getAllRecipients()); // 7. 关闭连接
transport.close(); return "success";
}
/**
* 创建邮件(带附件)
*
* com.nenu.controller
* @param session
* @param sendMail
* @param receiveMail
* @param title
* @param path
* @param context
* @return
* @throws Exception MimeMessage
* created at 2018年12月6日
*/
public static MimeMessage createMimeMessage(Session session, String sendMail, String receiveMail,String title,String path,String context) throws Exception {
// 1. 创建邮件对象
MimeMessage message = new MimeMessage(session); // 2. From: 发件人
message.setFrom(new InternetAddress(sendMail, "This is lick", "UTF-8")); // 3. To: 收件人(可以增加多个收件人、抄送、密送)
message.addRecipient(RecipientType.TO, new InternetAddress(receiveMail, "This is lick", "UTF-8")); // 4. Subject: 邮件主题
message.setSubject(title, "UTF-8"); /*
* 下面是邮件内容的创建:
*/ // 5. 创建图片“节点”
// MimeBodyPart image = new MimeBodyPart();
// DataHandler dh = new DataHandler(new FileDataSource("C:\\Users\\nenu\\Desktop\\ss.jpg")); // 读取本地文件
// image.setDataHandler(dh); // 将图片数据添加到“节点”
// image.setContentID("image_fairy_tail"); // 为“节点”设置一个唯一编号(在文本“节点”将引用该ID) // // 6. 创建文本“节点”
MimeBodyPart text = new MimeBodyPart();
// // 这里添加图片的方式是将整个图片包含到邮件内容中, 实际上也可以以 http 链接的形式添加网络图片
// text.setContent("这是一张图片<br/><img src='cid:image_fairy_tail'/>", "text/html;charset=UTF-8");
text.setContent(context, "text/html;charset=UTF-8");
//
// // 7. (文本+图片)设置 文本 和 图片 “节点”的关系(将 文本 和 图片 “节点”合成一个混合“节点”)
// MimeMultipart mm_text_image = new MimeMultipart();
// mm_text_image.addBodyPart(text);
// mm_text_image.addBodyPart(image);
// mm_text_image.setSubType("related"); // 关联关系 // 8. 将 文本+图片 的混合“节点”封装成一个普通“节点”
// 最终添加到邮件的 Content 是由多个 BodyPart 组成的 Multipart, 所以我们需要的是 BodyPart,
// 上面的 mm_text_image 并非 BodyPart, 所有要把 mm_text_image 封装成一个 BodyPart
// MimeBodyPart text_image = new MimeBodyPart();
// text_image.setContent(mm_text_image); // 9. 创建附件“节点”
MimeBodyPart attachment = new MimeBodyPart();
DataHandler dh2 = new DataHandler(new FileDataSource(path)); // 读取本地文件
attachment.setDataHandler(dh2); // 将附件数据添加到“节点”
attachment.setFileName(MimeUtility.encodeWord(dh2.getName())); // 设置附件的文件名(需要编码) // 10. 设置(文本+图片)和 附件 的关系(合成一个大的混合“节点” / Multipart )
MimeMultipart mm = new MimeMultipart();
mm.addBodyPart(text);
mm.addBodyPart(attachment); // 如果有多个附件,可以创建多个多次添加
mm.setSubType("mixed"); // 混合关系 // 11. 设置整个邮件的关系(将最终的混合“节点”作为邮件的内容添加到邮件对象)
message.setContent(mm); // 12. 设置发件时间
message.setSentDate(new Date()); // 13. 保存上面的所有设置
message.saveChanges(); return message;
} }
效果演示
github地址:https://github.com/lick468/email_demo.git
spring boot 邮件发送(带附件)的更多相关文章
- java mail邮件发送(带附件) 支持SSL
java mail邮件发送(带附件)有三个类 MailSenderInfo.java package mail; import java.util.Properties; import java.ut ...
- Spring Boot 邮件发送的 5 种姿势!
邮件发送其实是一个非常常见的需求,用户注册,找回密码等地方,都会用到,使用 JavaSE 代码发送邮件,步骤还是挺繁琐的,Spring Boot 中对于邮件发送,提供了相关的自动化配置类,使得邮件发送 ...
- Spring Boot 邮件发送
pom文件依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifactId> ...
- Spring的javaMail邮件发送(带附件)
项目中经常用到邮件功能,在这里简单的做一下笔记,方便日后温习. 首先需要在配置文件jdbc.properties添加: #------------ Mail ------------ mail.smt ...
- spring boot 邮件服务
引入依赖 添加spring-boot-starter-mail包引用 <dependency> <groupId>org.springframework.boot</gr ...
- [SpringBoot] - 发送带附件的邮件
<!--发送email依赖--> <dependency> <groupId>org.springframework.boot</groupId> &l ...
- ORACLE发送带附件邮件的二三事之一
在oracle使用过程中,我们可以通过pl/sql生成数据文件,也可以通过spool on spool off生成,但某些环境下,我们需要通过存储过程处理数据,数据处理完,需要自动生成数据文件,手工导 ...
- 使用Spring发送带附件的电子邮件(站内和站外传送)
JavaMail的介绍 JavaMail,顾名思义,提供给开发者处理电子邮件相关的编程接口.它是Sun发布的用来处理email的API.它可以方便地执行一些常用的邮件传输. 虽然JavaMail是 ...
- java发送带附件的邮件
/** * java发送带附件的邮件 * 周枫 * 2013.8.10 */ package com.dsideal.Util; import javax.mail.*; import javax.m ...
随机推荐
- selenium webdriver窗口切换(下)
多窗口切换有时候需要在不同的窗口切换,从而操作不同的窗口上的元素.在selenium1.0 中这个问题比较难处理.但WebDriver 提供了switcTo.window()方法可以切换到任意的窗口. ...
- python直接赋值、浅拷贝和深拷贝
# 解: # import copy # names1=['Amir','Barry','Cgakes','Dao',[11,22,33]] # names2=names1#直接赋值,指向同一个对象 ...
- c#获取指定时区的日期
1.首先将服务器的时间转化为utc时间,然后转换成指定时区的日期 public DateTime GetSpecificZoneNowDate(string zoneName = "Chin ...
- 003-ubuntu上安装mysql
安装如下: 1.安装服务端:# sudo apt-get install mysql-server. 2.安装客户端:# sudo apt-get -y install mysql-server. ...
- 兼容安卓和ios实现一键复制内容到剪切板
实现代码如下: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <m ...
- MIPSsim使用说明
MIPSsim下载:https://files.cnblogs.com/files/jiangxinnju/MIPSsim.zip 启动模拟器 双击MIPSsim.exe,即可启动该模拟器.MIPSs ...
- linux服务器文件索引inodes满了
inode节点中,记录了文件的类型.大小.权限.所有者.文件连接的数目.创建时间与更新时间等重要的信息,还有一个比较重要的内容就是指向数据块的指针.一般情况不需要特殊配置,如果存放文件很多,需要配置. ...
- div居中布局
利用margin属性可以实现div居中布局,把div的左边距和右边距设置为auto即可,代码如下 <!DOCTYPE html> <html> <head> < ...
- MySQL Crash Course #01# Chapter 1. 2 概念. Primary key
索引 database table schema Primary Key MySQL 书的第一章介绍一些基本的概念.理解数据库是掌握 MySQL 非常重要的一个部分. 第二章简单介绍了 MySQL 以 ...
- jdbc连接池c3p0/dbcp强制连接超过设置时间后失效
通常来说,各种技术实现的优化参数或者选项或者歪门邪道之所以能被想出来,通常是因为开发者或者实现的贡献者曾经遇到过导致此结果的问题,所以才出了对应的策略选项. 在有些情况下,比如存在客户端或者服务端连接 ...