2016-12-06 18 views
1

私は指示に電子メールを送信しようとしている:https://cloud.google.com/appengine/docs/java/mail/sending-mail-with-mail-apiGoogle Appsのエンジンでメールを送信する

しかし、私はこのエラーを取得する:

com.google.apphosting.api.ApiProxy$CancelledException: The API call remote_socket.CreateSocket() was explicitly cancelled. 
at com.google.apphosting.api.ApiProxy.makeSyncCall (ApiProxy.java:118) 
at com.google.apphosting.api.ApiProxy.makeSyncCall (ApiProxy.java:67) 
at com.google.appengine.api.socket.SocketApiHelper.apiProxyMakeSyncCall (SocketApiHelper.java:93) 
at com.google.appengine.api.socket.SocketApiHelper.makeSyncCall (SocketApiHelper.java:58) 
at com.google.appengine.api.socket.AppEngineSocketImpl.createSocket (AppEngineSocketImpl.java:497) 
at com.google.appengine.api.socket.AppEngineSocketImpl.connectToAddress (AppEngineSocketImpl.java:362) 
at com.google.appengine.api.socket.AppEngineSocketImpl.connect (AppEngineSocketImpl.java:352) 
at java.net.Socket.connect (Socket.java:612) 
at java.net.Socket.connect (Socket.java:540) 
at com.sun.mail.util.SocketFetcher.createSocket (SocketFetcher.java:321) 
at com.sun.mail.util.SocketFetcher.getSocket (SocketFetcher.java:237) 
at com.sun.mail.smtp.SMTPTransport.openServer (SMTPTransport.java:1927) 
at com.sun.mail.smtp.SMTPTransport.protocolConnect (SMTPTransport.java:654) 
at javax.mail.Service.connect (Service.java:295) 
at javax.mail.Service.connect (Service.java:176) 
at javax.mail.Service.connect (Service.java:125) 
at javax.mail.Transport.send0 (Transport.java:194) 
at javax.mail.Transport.send (Transport.java:124) 
at ru.usyservice.model.mail.PopupMail.sendMail (PopupMail.java:88) 

理由何ができますか?

私の方法:

private void sendMail(String mail) { 
     Properties props = new Properties(); 
     Session session = Session.getDefaultInstance(props, null); 

     try { 
      Message msg = new MimeMessage(session); 
      msg.setFrom(new InternetAddress("[email protected]", "Mr.x")); 
      msg.addRecipient(Message.RecipientType.TO, 
        new InternetAddress("[email protected]", "Mr.y")); 
      msg.setSubject("Test mail"); 
      msg.setContent(mail, "text/html; charset=\"UTF-8\""); 
      Transport.send(msg); 
     } catch (AddressException e) { 
      e.printStackTrace(); 
     } catch (MessagingException e) { 
      e.printStackTrace(); 
     } catch (UnsupportedEncodingException e) { 
      e.printStackTrace(); 
     } 
    } 
+0

Google App Engineで約1年前と同様の問題は発生しませんでした。解決策は、送信が失敗した場合にメールを再試行する別のキュー/スレッドを作成する必要があることでした。 Google App Engineにはこれを行うサービスがあり、サンプルコードを提供しています。マルチスレッドコードは実際にはサポートされていないので、自分でコード化できるものではありません。 また、メールの送信を設定し、アカウントが許可された最大送信数を増やすために必要ないくつかの手順がありました。 – mba12

+0

ありがとうございました! しかし、pom.xmlに間違いがあります –

答えて

1

私は、ライブラリのjavax.mailが追加されている、のpom.xmlに誤りを見つけましたが、GoogleはAppEngineの-API-1.0-SDKに含まれている彼のlibが、使用しています Mavenでjavax.mailを削除し、appengine-api-1.0-sdkを追加しました。

関連する問題