java 发邮件

很多项目都可能会用到发邮件功能,实现非常简单。

1 引入java发邮件用到的jar包

XML 复制代码
 <!-- https://mvnrepository.com/artifact/javax.mail/mail -->
        <dependency>
            <groupId>javax.mail</groupId>
            <artifactId>mail</artifactId>
            <version>1.4.7</version>
        </dependency>

2 java发邮件代码

XML 复制代码
import javax.mail.*;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;
import java.util.Properties;

public class EmailUtil {

    /**
     * 邮件工具类
     */

        /**
         * 发送邮件
         * @param to 给谁发
         * @param text 发送内容
         */
        public static void send_mail(String to,String text) throws MessagingException {
            //创建连接对象 连接到邮件服务器
            Properties properties = new Properties();
            //设置发送邮件的基本参数
            //发送邮件服务器
            properties.put("mail.smtp.host", "smtp.qq.com");
            //发送端口
            properties.put("mail.smtp.port", "587");
            properties.put("mail.smtp.auth", "true");
            //设置发送邮件的账号和密码
            Session session = Session.getInstance(properties, new Authenticator() {
                @Override
                protected PasswordAuthentication getPasswordAuthentication() {
                    //两个参数分别是发送邮件的账户和密码(授权码)
                    return new PasswordAuthentication("xxxxx@qq.com","密码");
                }
            });

            //创建邮件对象
            Message message = new MimeMessage(session);
            //设置发件人
            message.setFrom(new InternetAddress("发出邮箱的地址"));
            //设置收件人
            message.setRecipient(Message.RecipientType.TO,new InternetAddress(to));
            //设置主题
            message.setSubject("验证邮箱");
            //设置邮件正文  第二个参数是邮件发送的类型
            message.setContent(text,"text/html;charset=UTF-8");
            //发送一封邮件
            Transport.send(message);
        }

}
相关推荐
KaiwuDB4 分钟前
深度剖析:KWDB SQL 编译与优化策略
数据库
翰林小院6 分钟前
【MongoDB】 MongoDB index overview
数据库·mongodb
该用户已不存在7 分钟前
我的Python工具箱,不用加班的秘密
前端·后端·python
郑重其事,鹏程万里12 分钟前
commons-io
java
Albert Edison13 分钟前
【MySQL】数据类型
数据库·mysql·adb·oracle
星期天要睡觉18 分钟前
计算机视觉(opencv)——实时颜色检测
人工智能·python·opencv·计算机视觉
遇见火星19 分钟前
MYSQL-物理备份(xtrabackup)使用指南
数据库·mysql·adb
aerror24 分钟前
json转excel xlsx文件
开发语言·python·json
爱吃烤鸡翅的酸菜鱼25 分钟前
从零掌握贪心算法Java版:LeetCode 10题实战解析(上)
java·算法
爱可生开源社区42 分钟前
医疗业务系统升级,这家三甲医院为何牵手 OceanBase?(SQLServer->OceanBase)
数据库