这是一个前辈实现了的功能代码,就在这装作是自己实现的来记录一下。
import com.sun.mail.util.MailSSLSocketFactory;
import javax.mail.*;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;
import java.io.UnsupportedEncodingException;
import java.security.GeneralSecurityException;
import java.util.Date;
import java.util.Properties;
public class MailService {
public static void sendEmail(String toAddress,String number) {
Properties prop = new Properties();
//协议
prop.setProperty("mail.transport.protocol", "smtp");
//服务器
prop.setProperty("mail.smtp.host", "smtp.exmail.qq.com");
//端口
prop.setProperty("mail.smtp.port", "465");
//使用smtp身份验证
prop.setProperty("mail.smtp.auth", "true");
//使用SSL,企业邮箱必需!
//开启安全协议
MailSSLSocketFactory sf = null;
try {
sf = new MailSSLSocketFactory();
sf.setTrustAllHosts(true);
} catch (GeneralSecurityException e1) {
e1.printStackTrace();
}
prop.put("mail.smtp.ssl.enable", "true");
prop.put("mail.smtp.ssl.socketFactory", sf);
//获取Session对象
Session s = Session.getDefaultInstance(prop,new Authenticator() {
//此访求返回用户和密码的对象
@Override
protected PasswordAuthentication getPasswordAuthentication() {
PasswordAuthentication pa = new PasswordAuthentication("gongze_yan@666.com", "LoveU");
return pa;
}
});
//设置session的调试模式,发布时取消
s.setDebug(true);
MimeMessage mimeMessage = new MimeMessage(s);
try {
mimeMessage.setFrom(new InternetAddress("gongze_yan@666.com","gongze_yan@666.com"));
mimeMessage.addRecipient(Message.RecipientType.TO, new InternetAddress(toAddress));
mimeMessage.setSentDate(new Date());
//设置主题
mimeMessage.setSubject("能力开放平台密码重置");
//设置内容
mimeMessage.setText("您好,您的密码重置为" + number + ",为了您的账户安全,请及时修改密码");
mimeMessage.saveChanges();
//发送
Transport.send(mimeMessage);
} catch (MessagingException e) {
e.printStackTrace();
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
}
}
这个位置设置的是作为服务器邮箱的账号和密码。
如果用QQ邮箱作为服务器邮箱进行测试的话需要设置开启POP3/SMTP,在“账号”里一直往下撸,在密码的位置输入生成的授权码即可。
至于下面这个位置这东西是啥我也不太知道,反正就写成一样的就可以了。