- JavaMail API 教程
- JavaMail - 首頁
- JavaMail API - 概述
- JavaMail - 環境設定
- JavaMail - 核心類
- JavaMail - 傳送郵件
- JavaMail - 檢查郵件
- JavaMail - 獲取郵件
- JavaMail - 身份驗證
- JavaMail - 回覆郵件
- JavaMail - 轉發郵件
- JavaMail - 刪除郵件
- JavaMail - Gmail SMTP 伺服器
- JavaMail - 資料夾管理
- JavaMail - 配額管理
- JavaMail - 退信
- JavaMail API 協議
- JavaMail - SMTP 伺服器
- JavaMail - IMAP 伺服器
- JavaMail - POP3 伺服器
- JavaMail API 有用資源
- JavaMail - 快速指南
- JavaMail - 有用資源
- JavaMail - 討論
JavaMail API - 傳送簡單郵件
這是一個傳送簡單郵件的示例。在這裡,我們使用了 JangoSMPT 伺服器,透過它將郵件傳送到我們的目標電子郵件地址。設定在環境設定章節中進行了說明。
傳送簡單郵件的步驟如下
獲取會話
建立一個預設的 MimeMessage 物件,並在郵件中設定發件人、收件人、主題。
將實際郵件設定為
message.setText("your text goes here");使用 Transport 物件傳送郵件。
建立 Java 類
建立一個名為SendEmail的 Java 類檔案,其內容如下
package com.tutorialspoint;
import java.util.Properties;
import javax.mail.Message;
import javax.mail.MessagingException;
import javax.mail.PasswordAuthentication;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;
public class SendEmail {
public static void main(String[] args) {
// Recipient's email ID needs to be mentioned.
String to = "destinationemail@gmail.com";
// Sender's email ID needs to be mentioned
String from = "fromemail@gmail.com";
final String username = "manishaspatil";//change accordingly
final String password = "******";//change accordingly
// Assuming you are sending email through relay.jangosmtp.net
String host = "relay.jangosmtp.net";
Properties props = new Properties();
props.put("mail.smtp.auth", "true");
props.put("mail.smtp.starttls.enable", "true");
props.put("mail.smtp.host", host);
props.put("mail.smtp.port", "25");
// Get the Session object.
Session session = Session.getInstance(props,
new javax.mail.Authenticator() {
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(username, password);
}
});
try {
// Create a default MimeMessage object.
Message message = new MimeMessage(session);
// Set From: header field of the header.
message.setFrom(new InternetAddress(from));
// Set To: header field of the header.
message.setRecipients(Message.RecipientType.TO,
InternetAddress.parse(to));
// Set Subject: header field
message.setSubject("Testing Subject");
// Now set the actual message
message.setText("Hello, this is sample for to check send " +
"email using JavaMailAPI ");
// Send message
Transport.send(message);
System.out.println("Sent message successfully....");
} catch (MessagingException e) {
throw new RuntimeException(e);
}
}
}
由於我們使用的是主機提供商 JangoSMTP 提供的 SMTP 伺服器,因此我們需要驗證使用者名稱和密碼。javax.mail.PasswordAuthentication類用於驗證密碼。
編譯並執行
現在我們的類已準備就緒,讓我們編譯上述類。我將 SendEmail.java 類儲存到目錄:/home/manisha/JavaMailAPIExercise。我們需要將javax.mail.jar和activation.jar這兩個 jar 包放在類路徑中。從命令提示符執行以下命令來編譯類(這兩個 jar 包都放在 /home/manisha/ 目錄中)
javac -cp /home/manisha/activation.jar:/home/manisha/javax.mail.jar: SendEmail.java
現在類已編譯,執行以下命令執行
java -cp /home/manisha/activation.jar:/home/manisha/javax.mail.jar: SendEmail
驗證輸出
您應該在命令控制檯上看到以下訊息
Sent message successfully....
由於我透過 JangoSMTP 向我的 Gmail 地址傳送郵件,因此我的 Gmail 帳戶收件箱中會收到以下郵件
javamail_api_sending_emails.htm
廣告