1

以下のプログラムを使用してメールを送信しようとしていますが、次のエラー メッセージが表示されます。

             public class SMTPTest {
    //private Logger log = Logger.getLogger(this.getClass());

    public boolean sendSimpleMail(String to, String subject, String body) {
        Properties props = new Properties();
        props.put("mail.smtp.user", "amrita_test");
        props.put("mail.smtp.password", "aview");
        props.put("mail.smtp.host", "192.168.0.25");
        props.put("mail.smtp.port", "25");
        props.put("mail.smtp.starttls.enable", "true");
        props.put("mail.smtp.auth", "true");
        // props.put("mail.smtp.debug", "true");
        props.put("mail.smtp.debug", "false");
        props.put("mail.smtp.socketFactory.port", "425");
        props.put("mail.smtp.socketFactory.class",
                "javax.net.ssl.SSLSocketFactory");
        props.put("mail.smtp.socketFactory.fallback", "false");
        try {
            Authenticator auth = new SMTPAuthenticator();
            Session session = Session.getInstance(props, auth);
            // session.setDebug(true);
            MimeMessage msg = new MimeMessage(session);
            String content = body;
            msg.setSubject(subject);
            msg.setFrom(new InternetAddress("buddhiedge@gmail.com"));
            Address[] addresses = new Address[1];
            addresses[0] = new InternetAddress("buddhiedge@gmail.com");
            msg.setReplyTo(addresses);
            msg.addRecipient(Message.RecipientType.TO, new InternetAddress(to));
            msg.setContent(content, "text/html");
            Transport.send(msg);
            return true;
        } catch (Exception mex) {
            mex.printStackTrace();
            System.out.println("Error in sending mail :: " + mex.getMessage());
            return false;
        }
    }

    private class SMTPAuthenticator extends Authenticator {
        public PasswordAuthentication getPasswordAuthentication() {
            return new PasswordAuthentication("amrita_test",
                    "aview");
        }
    }
    public static void main(String args[]){
        SMTPTest test=new SMTPTest();
        test.sendSimpleMail("praveenpkd@gmail.com", "subject", "body");
    }
}

エラー: javax.mail.MessagingException: SMTP ホストに接続できませんでした: 192.168.0.25、ポート: 25;

    nested exception is:
    java.net.ConnectException: Connection timed out: connect
    at com.sun.mail.smtp.SMTPTransport.openServer(SMTPTransport.java:1282)
    at com.sun.mail.smtp.SMTPTransport.protocolConnect(SMTPTransport.java:370)
    at javax.mail.Service.connect(Service.java:297)
    at javax.mail.Service.connect(Service.java:156)
    at javax.mail.Service.connect(Service.java:105)
    at javax.mail.Transport.send0(Transport.java:168)
    at javax.mail.Transport.send(Transport.java:98)
    at SMTPTest.sendSimpleMail(SMTPTest.java:45)
    at SMTPTest.main(SMTPTest.java:62)
Caused by: java.net.ConnectException: Connection timed out: connect
    at java.net.PlainSocketImpl.socketConnect(Native Method)
    at java.net.PlainSocketImpl.doConnect(PlainSocketImpl.java:333)
    at java.net.PlainSocketImpl.connectToAddress(PlainSocketImpl.java:195)
    at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:182)
    at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:366)
    at java.net.Socket.connect(Socket.java:519)
    at com.sun.net.ssl.internal.ssl.SSLSocketImpl.connect(SSLSocketImpl.java:550)
    at com.sun.net.ssl.internal.ssl.BaseSSLSocketImpl.connect(BaseSSLSocketImpl.java:141)
    at com.sun.mail.util.SocketFetcher.createSocket(SocketFetcher.java:232)
    at com.sun.mail.util.SocketFetcher.getSocket(SocketFetcher.java:163)
    at com.sun.mail.smtp.SMTPTransport.openServer(SMTPTransport.java:1250)
    ... 8 more

ただし、SMTP サーバーまたは接続に問題はありません。telnet 192.168.0.25 25 は正常に接続します。これを解決する方法。

4

2 に答える 2

0

認証の問題であれば、別のエラーが発生すると思います。

ネットワーク/SMTP サーバーは IP6 をサポートしていますか? クライアントが IP6 をサポートしている場合、Java の新しいバージョンではデフォルトで IP6 が使用されますが、多くの SMTP サーバーは IP4 で構成されています。IP4 を強制するように JVM を構成する方法については、こちらの記事「 Send email using JSP」を参照してください。これは、インスタンス化されるときに JVM で設定する必要があります。

于 2013-05-08T00:18:16.000 に答える