阿裏雲smtp郵件服務引發的血案
阿新 • • 發佈:2017-10-24
阿裏雲 smtp 郵件服務
前言
今天開發夥伴找我修改郵件服務smtp發現網站用郵箱找回密碼失敗了!於是我開始了簡單得操作!
首先我掃描一下!
發現25端口沒有連接服務。
看一下報錯!
之後telnet一下 telnet smtp.163.com 25發現找不到!
之後上網找一些資料發現阿裏的售後很早之前發過這樣的帖子 說25端口禁用了,之後又有查詢資料發現465端口ssl可以!
那麽問題找到了 那就需要將25端口換到465端口 采用SSL協議傳輸郵件。
好了貼代碼時間到:
下面這段代碼是采用SSL協議發送郵件,可向多人單人發送郵件
public static boolean sslSend(MessageInfo msg1, EmailAccount emailAccount) throws AddressException, MessagingException, IOException{ Security.addProvider(new com.sun.net.ssl.internal.ssl.Provider()); final String SSL_FACTORY = "javax.net.ssl.SSLSocketFactory"; // Get a Properties object Properties props = new Properties(); props.setProperty("mail.smtp.host", emailAccount.getPlace()); props.setProperty("mail.smtp.socketFactory.class", SSL_FACTORY); props.setProperty("mail.smtp.socketFactory.fallback", "false"); props.setProperty("mail.smtp.port", "465"); props.setProperty("mail.smtp.socketFactory.port", "465"); props.put("mail.smtp.auth", "true"); final String username = emailAccount.getUsername(); final String password = emailAccount.getPassword(); Session session = Session.getDefaultInstance(props, new Authenticator(){ protected PasswordAuthentication getPasswordAuthentication() { return new PasswordAuthentication(username, password); }}); Message msg = new MimeMessage(session); // 設置發件人和收件人 msg.setFrom(new InternetAddress(emailAccount.getUsername())); List<String> tos = msg1.getTo(); Address to[] = new InternetAddress[tos.size()]; for(int i=0;i<tos.size();i++){ to[i] = new InternetAddress(tos.get(i)); } // 多個收件人地址 msg.setRecipients(Message.RecipientType.TO, to); msg.setSubject(msg1.getSubject()); // 標題 msg.setText(msg1.getMsg());// 內容 msg.setSentDate(new Date()); Transport.send(msg); System.out.println("EmailUtil ssl協議郵件發送打印" +msg.toString()); return true; }
EmailAccout 字段
// 郵箱用戶 private String username; // 郵箱密碼 private String password; // 郵箱服務器 private String place;
MessageInfo 字段
@NameCN("發件人地址") private String from; @NameCN("收件人地址") private List<String> to; @NameCN("發送時間") private Date sendDate; @NameCN("郵件主題") private String subject; @NameCN("消息正文") private String msg;
將需要的信息,寫入這兩個Bean,傳入最上面的方法即可 使用。
下面是25端口 非SSl協議傳輸代碼塊
public void doSend(MessageInfo msg, EmailAccount emailAccount) { SimpleMailMessage simpleMailMessage = new SimpleMailMessage(); simpleMailMessage.setFrom(msg.getFrom());// 設置發送者地址 List<String> tos = msg.getTo(); String to[] = new String[tos.size()]; tos.toArray(to); simpleMailMessage.setTo(to);// 設置接受者地址,可多個 simpleMailMessage.setSubject(msg.getSubject()); simpleMailMessage.setSentDate(msg.getSendDate()); simpleMailMessage.setText(msg.getMsg()); simpleMailMessage.setFrom(emailAccount.getUsername()); System.out.println("EmailUtil 郵件發送打印 1111" + simpleMailMessage.toString()); JavaMailSenderImpl s = new JavaMailSenderImpl(); s.setHost(emailAccount.getPlace()); // s.setPort(25); s.setUsername(emailAccount.getUsername()); s.setPassword(emailAccount.getPassword()); s.send(simpleMailMessage); }
這是參考的引入
import java.io.IOException; import java.security.Security; import java.util.Date; import java.util.List; import java.util.Properties; import javax.mail.Address; import javax.mail.Authenticator; import javax.mail.Message; import javax.mail.MessagingException; import javax.mail.PasswordAuthentication; import javax.mail.Session; import javax.mail.Transport; import javax.mail.internet.AddressException; import javax.mail.internet.InternetAddress; import javax.mail.internet.MimeMessage; import org.springframework.mail.SimpleMailMessage; import org.springframework.mail.javamail.JavaMailSenderImpl; import org.springframework.mail.javamail.MimeMessageHelper; import 項目包名.MessageInfo; import 項目包名.EmailAccount;
javamail是spring裏的javamail jar包。
OK當我們使用465端口SSL協議的時候,順利的在服務器上發出郵件了。
註意!需要在阿裏雲的安全組把465端口寫上!
自後在掃描一下看看是否支持465端口!已經open了!
看一下郵箱是否收到驗證碼!
輸入郵箱找回密碼!
查看郵箱!
總結!勤動腦多喝六個核桃!
本文出自 “李世龍” 博客,謝絕轉載!
阿裏雲smtp郵件服務引發的血案