mail-service.xmlファイルからセッションを取得しているときにjbossからメールを送信しようとしています。
javax.naming.Context ictx = new javax.naming.InitialContext();
Session mailSession = (Session) ictx.lookup("java:/Mail");
これは私のmail-service.xmlファイルです
<?xml version="1.0" encoding="UTF-8"?>
<!--DOCTYPE server-->
<!-- $Id: mail-service.xml,v 1.5 2003/08/27 04:34:12 patriot1burke Exp $ -->
<server>
<!-- ==================================================================== -->
<!-- Mail Connection Factory -->
<!-- ==================================================================== -->
<mbean code="org.jboss.mail.MailService"
name="jboss:service=Mail">
<attribute name="JNDIName">java:/Mail</attribute>
<attribute name="User">nobody</attribute>
<attribute name="Password">password</attribute>
<attribute name="Configuration">
<!-- Test -->
<configuration>
<property name="mail.smtp.starttls.enable" value="true"/>
<property name="mail.smtp.host" value="smtp.gmail.com"/>
<property name="mail.smtp.user" value="***"/>
<property name="mail.smtp.password" value="***"/>
<property name="mail.smtp.port" value="587"/>
<property name="mail.smtp.auth" value="true"/>
<property name="mail.debug" value="true"/>
</configuration>
</attribute>
</mbean>
</server>
しかし、認証に失敗した例外という出力が表示されます。
16:29:37,562 INFO [STDOUT] 220 mx.google.com ESMTP ku7sm11540452pbc.31
16:29:37,578 INFO [STDOUT] DEBUG SMTP: connected to host "smtp.gmail.com", port
: 587
16:29:37,578 INFO [STDOUT] EHLO cl-4
16:29:38,000 INFO [STDOUT] 250-mx.google.com at your service, [101.63.150.159]
250-SIZE 35882577
250-8BITMIME
250-STARTTLS
250 ENHANCEDSTATUSCODES
16:29:38,000 INFO [STDOUT] DEBUG SMTP: Found extension "SIZE", arg "35882577"
16:29:38,000 INFO [STDOUT] DEBUG SMTP: Found extension "8BITMIME", arg ""
16:29:38,000 INFO [STDOUT] DEBUG SMTP: Found extension "STARTTLS", arg ""
16:29:38,000 INFO [STDOUT] DEBUG SMTP: Found extension "ENHANCEDSTATUSCODES", a
rg ""
16:29:38,000 INFO [STDOUT] STARTTLS
16:29:38,453 INFO [STDOUT] 220 2.0.0 Ready to start TLS
16:29:38,718 INFO [STDOUT] EHLO cl-4
16:29:40,750 INFO [STDOUT] 250-mx.google.com at your service, [101.63.150.159]
250-SIZE 35882577
250-8BITMIME
250-AUTH LOGIN PLAIN XOAUTH
250 ENHANCEDSTATUSCODES
16:29:40,750 INFO [STDOUT] DEBUG SMTP: Found extension "SIZE", arg "35882577"
16:29:40,765 INFO [STDOUT] DEBUG SMTP: Found extension "8BITMIME", arg ""
16:29:40,765 INFO [STDOUT] DEBUG SMTP: Found extension "AUTH", arg "LOGIN PLAIN
XOAUTH"
16:29:40,765 INFO [STDOUT] DEBUG SMTP: Found extension "ENHANCEDSTATUSCODES", a
rg ""
16:29:40,765 INFO [STDOUT] DEBUG SMTP: Attempt to authenticate
16:29:40,765 INFO [STDOUT] AUTH LOGIN
16:29:41,187 INFO [STDOUT] 334 VXNlcm5hbWU6
16:29:41,187 INFO [STDOUT] bm9b2R5
16:29:41,625 INFO [STDOUT] 34 UGFzc3dvcmQ6
16:29:41,625 INFO [STDOUT] cFzc3dvcmQ=
16:29:42,062 INFO [STDOUT] 535-5.7.1 Username and Password not accepted. Learn
more at
535 5.7.1 http://support.google.com/mail/bin/answer.py?answer=14257 ku7sm1154045
2pbc.31
16:29:42,062 INFO [STDOUT] in sendmail1 javax.mail.AuthenticationFailedExceptio
n
この問題を検索して、このリンクを見つけました。これは、オーセンティケーターを使用する必要があることを示しています。mail-service.xml
しかし、問題は、リンクでコードがファイルからのセッションを使用しないことです。すべてがプログラム自体にハードコーディングされています。からセッションを取得するときに、このオーセンティケーターをどのように使用する必要がありmail-service.xml
ますか?
編集
mail-service.xmlファイルのユーザー属性とパスワード属性にそれぞれ「mail.smtp.user」と「mail.smtp.password」の値を追加しました。それは働き始めました。
<server>
<!-- ==================================================================== -->
<!-- Mail Connection Factory -->
<!-- ==================================================================== -->
<mbean code="org.jboss.mail.MailService"
name="jboss:service=Mail">
<attribute name="JNDIName">java:/Mail</attribute>
<attribute name="User">***</attribute>
<attribute name="Password">***</attribute>
<attribute name="Configuration">
<!-- Test -->
<configuration>
<property name="mail.smtp.starttls.enable" value="true"/>
<property name="mail.smtp.host" value="smtp.gmail.com"/>
<property name="mail.smtp.user" value="***"/>
<property name="mail.smtp.password" value="***"/>
<property name="mail.smtp.port" value="587"/>
<property name="mail.smtp.auth" value="true"/>
<property name="mail.debug" value="true"/>
</configuration>
</attribute>
</mbean>
</server><br>
しかし、私はすでに「mail.smtp.user」と「mail.smtp.password」の値でユーザーとパスワードを指定しています。なぜそこから読めないのですか?その目的のためにそこにありますよね?