17

でやってsendMail ServletJavaMailます。私はjavax.mail.AuthenticationFailedException自分の出力を持っています。誰でも私を助けてもらえますか?ありがとう。

sendMailServlet コード:

try {
        String host = "smtp.gmail.com";
        String from = "my@gmail.com";
        String pass = "pass";
        Properties props = System.getProperties();
        props.put("mail.smtp.starttls.enable", "true");
        props.put("mail.smtp.host", host);
        props.put("mail.smtp.user", from);
        props.put("mail.smtp.password", pass);
        props.put("mail.smtp.port", "587");
        props.put("mail.smtp.auth", "true");
        props.put("mail.debug", "true");

        Session session = Session.getDefaultInstance(props, null);
        MimeMessage message = new MimeMessage(session);
        Address fromAddress = new InternetAddress(from);
        Address toAddress = new InternetAddress("test1@gmail.com");

        message.setFrom(fromAddress);
        message.setRecipient(Message.RecipientType.TO, toAddress);

        message.setSubject("Testing JavaMail");
        message.setText("Welcome to JavaMail");
        Transport transport = session.getTransport("smtp");
        transport.connect(host, from, pass);
        message.saveChanges();
        Transport.send(message);
        transport.close();

    }catch(Exception ex){

        out.println("<html><head></head><body>");
        out.println("ERROR: " + ex);
        out.println("</body></html>");
    }

GlassFish 2.1 での出力:

DEBUG SMTP: trying to connect to host "smtp.gmail.com", port 587, isSSL false
220 mx.google.com ESMTP 36sm10907668yxh.13
DEBUG SMTP: connected to host "smtp.gmail.com", port: 587
EHLO platform-4cfaca
250-mx.google.com at your service, [203.126.159.130]
250-SIZE 35651584
250-8BITMIME
250-STARTTLS
250-ENHANCEDSTATUSCODES
250 PIPELINING
DEBUG SMTP: Found extension "SIZE", arg "35651584"
DEBUG SMTP: Found extension "8BITMIME", arg ""
DEBUG SMTP: Found extension "STARTTLS", arg ""
DEBUG SMTP: Found extension "ENHANCEDSTATUSCODES", arg ""
DEBUG SMTP: Found extension "PIPELINING", arg ""
STARTTLS
220 2.0.0 Ready to start TLS
EHLO platform-4cfaca
250-mx.google.com at your service, [203.126.159.130]
250-SIZE 35651584
250-8BITMIME
250-AUTH LOGIN PLAIN
250-ENHANCEDSTATUSCODES
250 PIPELINING
DEBUG SMTP: Found extension "SIZE", arg "35651584"
DEBUG SMTP: Found extension "8BITMIME", arg ""
DEBUG SMTP: Found extension "AUTH", arg "LOGIN PLAIN"
DEBUG SMTP: Found extension "ENHANCEDSTATUSCODES", arg ""
DEBUG SMTP: Found extension "PIPELINING", arg ""
DEBUG SMTP: Attempt to authenticate
AUTH LOGIN
334 VXNlcm5hbWU6
aWpveWNlbGVvbmdAZ21haWwuY29t
334 UGFzc3dvcmQ6
MTIzNDU2Nzhf
235 2.7.0 Accepted
DEBUG: getProvider() returning javax.mail.Provider[TRANSPORT,smtp,com.sun.mail.smtp.SMTPTransport,Sun Microsystems, Inc]
DEBUG SMTP: useEhlo true, useAuth true
4

6 に答える 6

20

カスタムを実装する必要がありますAuthenticator

import javax.mail.Authenticator;
import javax.mail.PasswordAuthentication;


class GMailAuthenticator extends Authenticator {
     String user;
     String pw;
     public GMailAuthenticator (String username, String password)
     {
        super();
        this.user = username;
        this.pw = password;
     }
    public PasswordAuthentication getPasswordAuthentication()
    {
       return new PasswordAuthentication(user, pw);
    }
}

今すぐそれを使用してくださいSession

Session session = Session.getInstance(props, new GMailAuthenticator(username, password));

JavaMail FAQも参照してください。

于 2010-01-12T11:39:25.670 に答える
2

以下の行にこのオーセンティケーター オブジェクトの引数がありませんでした

Session session = Session.getInstance(props, new GMailAuthenticator(username, password));

この行で問題が解決し、Java アプリケーションを介してメールを送信できるようになりました。コードの残りの部分は、上記と同じように単純です。

于 2011-06-13T19:04:41.430 に答える
0

問題は、transportオブジェクトを作成し、その接続メソッドを使用して自分自身を認証していることです。ただし、staticメソッドを使用して、オブジェクトによって行われた認証を無視するメッセージを送信します。

したがって、sendMessage(message, message.getAllRecipients())オブジェクトでメソッドを使用するか、他の人が提案するようにオーセンティケーターを使用して、セッションを通じて承認を取得する必要があります。

ここにJava Mail FAQがあります。読む必要があります。

于 2012-11-26T06:22:10.220 に答える
0

あなたと共有したいだけです:
Digital Ocean マシン (IP アドレス) を変更した後、たまたまこのエラーが発生しました。どうやら Gmail はハッキング攻撃と認識したようです。彼らの指示に従い、新しい IP アドレスを承認すると、コードが戻って実行されます。

于 2014-09-04T14:02:14.157 に答える