0

電子メール用にGlassfishを構成するための参照をかなり見つけましたが、自分の問題を解決することができず、誰かが助けてくれることを望んでいます。

Glassfish 3.12コンソールで、メールホスト、ユーザー、送信者アドレス、および説明を使用してJavaMailセッションを構成しました。トランスポートプロトコルがSMTPに設定されており、mail.smtp.host(およびmail.smtp.auth = false)プロパティを追加しました。

メールの送信に使用しているコードは次のとおりです。

public class JndiMail {
    @Resource(name = "mail/[my-email]")
    private Session mailSession;

    public void sendMessage() {
        Message msg = new MimeMessage(mailSession);
        try {
          msg.setSubject("[app] Email Alert");
          msg.setRecipient(RecipientType.TO,
            new InternetAddress("user@domain",
            "User name"));
          msg.setText("Hello ");
          Transport.send(msg);
        }
        catch(MessagingException me) {
          System.out.println(me.toString());
        }
        catch(UnsupportedEncodingException uee) {
        }
      }
}

アプリケーションが電子メールを送信するたびに、ローカルホストが電子メールを拒否したことを示すログメッセージが表示されます。ローカルホストではなく、リモートExchangeサーバーを使用しようとしています。リモートメールサーバーにアクセスできない理由がわかりませんか?これはかなり簡単なことだと思いますので、何か見落としがあった場合はお詫び申し上げます。

Glassfishのログは次のとおりです。

[#|2013-03-26T10:00:39.334+1100|INFO|glassfish3.1.1|javax.enterprise.system.std.com.sun.enterprise.server.logging|_ThreadID=29;_ThreadName=Thread-2;|DEBUG: getProvider() returning javax.mail.Provider[TRANSPORT,smtp,com.sun.mail.smtp.SMTPTransport,Sun Microsystems, Inc]|#]

[#|2013-03-26T10:00:39.334+1100|INFO|glassfish3.1.1|javax.enterprise.system.std.com.sun.enterprise.server.logging|_ThreadID=29;_ThreadName=Thread-2;|DEBUG SMTP: useEhlo true, useAuth false|#]

[#|2013-03-26T10:00:39.334+1100|INFO|glassfish3.1.1|javax.enterprise.system.std.com.sun.enterprise.server.logging|_ThreadID=29;_ThreadName=Thread-2;|DEBUG SMTP: trying to connect to host "localhost", port 25, isSSL false|#]
4

1 に答える 1

1

私はこれを解決しました。解決策はかなり簡単です。GlassfishでJavamailリソースを設定するときは、JNDI名に「mail/」プレフィックスを使用することが重要です。Glassfishがこれを追加したと思いました。上記のコードからインジェクションを削除し、trycatchにJNDIルックアップを含めることで解決策を見つけました。

try {
    InitialContext ctx = new InitialContext();  
Session session = (Session) ctx.lookup("mail/MyEmail"); 
 Message msg = new MimeMessage(session);
于 2013-03-26T05:54:44.883 に答える