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.jaractivation.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 Send Email
javamail_api_sending_emails.htm
廣告

© . All rights reserved.