電子メール用に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|#]