2

smtp に接続しようとすると、このエラーが発生します

javax.mail.MessagingException: 334 eyJzdGF0dXMiOiI0MDAiLCJzY2hlbWVzIjoiQmVhcmVyIiwic2NvcGUiOiJodHRwczovL21haWwuZ29vZ2xlLmNvbS8ifQ==

これが私のコードです

public class GMailOauthSender
{
    private Session session;

    public SMTPTransport connectToSmtp(String host, int port, String userEmail, String oauthToken, boolean debug) throws Exception {

        Properties props = new Properties();
        props.put("mail.smtp.starttls.enable", "true");
        props.put("mail.smtp.starttls.required", "true");
        props.put("mail.smtp.sasl.enable", "false");
        session = Session.getInstance(props);
        session.setDebug(debug);

        final URLName unusedUrlName = null;
        SMTPTransport transport = new SMTPTransport(session, unusedUrlName);
        // If the password is non-null, SMTP tries to do AUTH LOGIN.
        final String emptyPassword = null;
        transport.connect(host, port, userEmail, emptyPassword);

        byte[] response = String.format("user=%s\1auth=Bearer %s\1\1", userEmail, oauthToken).getBytes();
        response = BASE64EncoderStream.encode(response);

        transport.issueCommand("AUTH XOAUTH2 " + new String(response), 235);

        return transport;
    }

    public synchronized void sendMail(String subject, String body, String user, String oauthToken, String recipients) {
        try {
            SMTPTransport smtpTransport = connectToSmtp("smtp.gmail.com",587,user,oauthToken,true);

            MimeMessage message = new MimeMessage(session);
            DataHandler handler = new DataHandler(new ByteArrayDataSource(body.getBytes(), "text/plain"));   
            message.setSender(new InternetAddress(user));   
            message.setSubject(subject);   
            message.setDataHandler(handler);   

            if (recipients.indexOf(',') > 0)   
                message.setRecipients(Message.RecipientType.TO, InternetAddress.parse(recipients));   
            else  
                message.setRecipient(Message.RecipientType.TO, new InternetAddress(recipients));   

            smtpTransport.sendMessage(message, message.getAllRecipients());   
        } catch (Exception e) {
            Log.d("test", e.getMessage());
        }
    }
}

スタックオーバーフローのどこかからこのコードを取得しました。何か助けて??

4

1 に答える 1

0

あなたが受け取っているエラー

eyJzdGF0dXMiOiI0MDAiLCJzY2hlbWVzIjoiQmVhcmVyIiwic2NvcGUiOiJodHRwczovL21haWwuZ29vZ2xlLmNvbS8ifQ==

Base64 Decoder を使用して次のようにデコードします

{"status":"400","schemes":"Bearer","scope":"https://mail.google.com/"}

これが最終的に意味することは (メッセージと同じくらい不可解ですが)、使用している認証トークンの有効期限が切れていることです。それを無効にしてから、新しいものを取得する必要があります (単にトークンを再度要求するだけです)。

次のようにトークンを無効にします。

mAccountManager.invalidateAuthToken("con.google", mAuthenticationToken);

これがお役に立てば幸いです:)

于 2013-11-19T18:59:42.377 に答える