6

一連の引数を受け取り、それらを使用して Exchange 2010 サーバーを使用して電子メールを送信する単純なメール送信者クラスを作成しようとしています。認証などは正常に機能しているように見えますが、コードが実際にメールを送信しようとすると、次の例外が発生します (と思います)。認証が機能していることを確認し、セッションからトランスポートを取得しましたが、それでも失敗します。私が間違っていることや行方不明になっていることについて、誰かが好きなことをすることができますか? ありがとう。

例外:

javax.mail.MessagingException: [EOF]
       at com.sun.mail.smtp.SMTPTransport.issueCommand(SMTPTransport.java:1481)
       at com.sun.mail.smtp.SMTPTransport.issueSendCommand(SMTPTransport.java:1512)
       at com.sun.mail.smtp.SMTPTransport.mailFrom(SMTPTransport.java:1054)
       at com.sun.mail.smtp.SMTPTransport.sendMessage(SMTPTransport.java:634)
       at javax.mail.Transport.send0(Transport.java:189)
       at javax.mail.Transport.send(Transport.java:140)
       at com.ri.common.mail.util.MailSender.sendHTMLEmail(MailSender.java:75)
       at com.ri.common.mail.util.MailSender.main(MailSender.java:106)

関連コード:

import java.util.Properties;

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.InternetAddress;
import javax.mail.internet.MimeMessage;


public class MailSender
{
    public static void sendHTMLEmail( String fromEmailId, String toEmailId, String host, String hostUserName,
            String hostPassword, String mailSubject, String mailBody )
    {
        // Get system properties.
        Properties props = System.getProperties();
        // Setup mail server
        props.put( "mail.transport.protocol", "smtp" );
        props.put( "mail.smtp.host", host );
        props.put( "mail.smtp.auth", "true" );

        final String hostUName = hostUserName;
        final String hPassword = hostPassword;

        Authenticator authenticator = new Authenticator()
        {
            protected PasswordAuthentication getPasswordAuthentication()
            {
                return new PasswordAuthentication( hostUName, hPassword );
            }
        };

        // Get the default Session object.
        Session session = Session.getDefaultInstance( props, authenticator );

        try
        {
            // Create a default MimeMessage object.
            MimeMessage message = new MimeMessage( session );

            // Set From: header field of the header.
            message.setFrom( new InternetAddress( fromEmailId ) );

            // Set To: header field of the header.
            message.addRecipient( Message.RecipientType.TO, new InternetAddress( toEmailId ) );

            // Set Subject: header field
            message.setSubject( mailSubject );

            // Send the actual HTML message, as big as you like
            message.setContent( mailBody, "text/html" );

            // Send message
            Transport.send( message, message.getAllRecipients() );
            System.out.println( "Sent message successfully...." );
        }
        catch( Exception mex )
        {
            mex.printStackTrace();
        }

    }

    public static void main( String[] args )
    {

        String to = "someCorrectEmailID@xyz.com";
        String from = "someCorrectEmailID@xyz.com";
        String host = "correctHostForExch2010";
        String user = "correctUser";
        String password = "CorrectPassword";
        String subject = "Test Email";
        String body = "Hi there. This is a test email!";

        MailSender.sendHTMLEmail( from, to, host, user, password, subject, body );
    }
}

編集:デバッグをオンにすると、

MAIL FROM:<someCorrectEmailID@xyz.com> 530 5.7.1 Client was not authenticated 
DEBUG SMTP: got response code 530, with response: 530 5.7.1 Client was not authenticated. 

セッション認証が成功したのはなぜですか?

4

3 に答える 3

6

アレックスとビルに感謝します。次のプロパティを有効にして動作させました。

props.put("mail.smtp.starttls.enable", "true");
于 2012-09-06T20:52:43.337 に答える
1

2 つの可能性:

  1. Session.getDefaultInstanceを使用しているため、実際に認証しようとしているわけではありません。
  2. クライアントとサーバーの両方がサポートする認証メカニズムが見つからないため、認証されていません。おそらく、サーバーが認証情報を送信する前に SSL を使用することを望んでいるためです。「mail.smtp.starttls.enable」を「true」に設定してみてください。

デバッグ出力をもっと見ることができれば、これらのどれが該当するかを知ることができます。

于 2012-09-06T20:20:46.260 に答える
0

また、このエラートレースがありました。私の修正は次のとおりです。

OS centos7 の場合: vi /etc/hosts に移動し、IP アドレスが正しいことを確認します。

于 2016-11-11T17:09:30.327 に答える