0

Google App Engineを使用してアプリケーションを作成しようとしています。この機能の一部には、サードパーティのサーバーからhttp経由でカレンダーデータを取得する必要があります。私が接続しているサーバはsslを使用していないことに注意することが重要です。したがって、ターゲットURLには「http://」のみが含まれます。Google App Engineテストサーバー(Java)でhttpリクエストを発行するとSSLHandshakeExceptionが発生する

とにかく、私は通常のJavaアプリケーションでいくつかのコードを概念の証明として書いています。

try { 

     // Create url 
     URL targetUrl = new URL(target); 

     // Open the connection 
     URLConnection connection = targetUrl.openConnection(); 

     // Create InputStream 
     InputStream inStream = connection.getInputStream(); 

     // Parse calendar data using iCal4j 
     CalendarBuilder builder = new CalendarBuilder(); 
     theCalendar = builder.build(inStream); 

     // Close the connection 
     inStream.close(); 

    } catch(IOException e) { 
     e.printStackTrace(); 
    } catch (ParserException e) { 
     e.printStackTrace(); 
    } 

このコードをJavaアプリケーションで実行したところ、魅力的でした。それを確認した後、Google App Engineプロジェクトの内部で作成したテスト用サーブレットに同じコードを実装しようと決めました。しかし、それが実行できるようにすると、私はこのエラーを取得:

javax.net.ssl.SSLHandshakeException: Could not verify SSL certificate for URL: http://the_url 
at com.google.appengine.api.urlfetch.URLFetchServiceImpl.convertApplicationException(URLFetchServiceImpl.java:175) 
at com.google.appengine.api.urlfetch.URLFetchServiceImpl.fetch(URLFetchServiceImpl.java:45) 
at com.google.apphosting.utils.security.urlfetch.URLFetchServiceStreamHandler$Connection.fetchResponse(URLFetchServiceStreamHandler.java:543) 
at com.google.apphosting.utils.security.urlfetch.URLFetchServiceStreamHandler$Connection.getInputStream(URLFetchServiceStreamHandler.java:422) 
at java.net.URL.openStream(URL.java:1037) 
at com.amftech.website.CalendarServlet.doGet(CalendarServlet.java:36) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:617) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:717) 
at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:511) 
at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1166) 
at com.google.appengine.api.socket.dev.DevSocketFilter.doFilter(DevSocketFilter.java:74) 
at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157) 
at com.google.appengine.tools.development.ResponseRewriterFilter.doFilter(ResponseRewriterFilter.java:134) 
at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157) 
at com.google.appengine.tools.development.HeaderVerificationFilter.doFilter(HeaderVerificationFilter.java:34) 
at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157) 
at com.google.appengine.api.blobstore.dev.ServeBlobFilter.doFilter(ServeBlobFilter.java:63) 
at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157) 
at com.google.apphosting.utils.servlet.TransactionCleanupFilter.doFilter(TransactionCleanupFilter.java:43) 
at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157) 
at com.google.appengine.tools.development.StaticFileFilter.doFilter(StaticFileFilter.java:122) 
at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157) 
at com.google.appengine.tools.development.DevAppServerModulesFilter.doDirectRequest(DevAppServerModulesFilter.java:366) 
at com.google.appengine.tools.development.DevAppServerModulesFilter.doDirectModuleRequest(DevAppServerModulesFilter.java:349) 
at com.google.appengine.tools.development.DevAppServerModulesFilter.doFilter(DevAppServerModulesFilter.java:116) 
at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157) 
at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:388) 
at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216) 
at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:182) 
at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:765) 
at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:418) 
at com.google.appengine.tools.development.DevAppEngineWebAppContext.handle(DevAppEngineWebAppContext.java:95) 
at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152) 
at com.google.appengine.tools.development.JettyContainerService$ApiProxyHandler.handle(JettyContainerService.java:508) 
at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152) 
at org.mortbay.jetty.Server.handle(Server.java:326) 
at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:542) 
at org.mortbay.jetty.HttpConnection$RequestHandler.headerComplete(HttpConnection.java:923) 
at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:547) 
at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:212) 
at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:404) 
at org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:409) 
at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:582) 

私はまた、サーバーの起動時に、次の警告が出力されたことに気づいた。

Jun 12, 2017 2:43:14 PM com.google.appengine.repackaged.com.google.protobuf.UnsafeUtil supportsUnsafeByteBufferOperations 
WARNING: platform method missing - proto runtime falling back to safer methods: java.security.AccessControlException: access denied ("java.lang.RuntimePermission" "accessClassInPackage.sun.misc") 
Jun 12, 2017 2:43:14 PM com.google.appengine.repackaged.com.google.protobuf.UnsafeUtil supportsUnsafeArrayOperations 
WARNING: platform method missing - proto runtime falling back to safer methods: java.security.AccessControlException: access denied ("java.lang.RuntimePermission" "accessClassInPackage.sun.misc") 
Jun 12, 2017 2:43:14 PM com.google.appengine.repackaged.com.google.protobuf.UnsafeUtil supportsUnsafeCopyMemory 
WARNING: copyMemory is missing from platform - proto runtime falling back to safer methods. 

これらの警告場合、私は知りません何かを意味する、しかし私は彼らがかもしれないと思った。テストサーバーの設定に問題はありますか?私のプロジェクトのセットアップ?私はインターネット全体を検索し、「あなたが証明書をダウンロードしたことを確認してください」を除いて何も見つかりませんでした。しかし、私が接続しているサーバはSSLを使用していないので、なぜSSLハンドシェイクについて不平を言いますか?

答えて

0

何が起きているのかよく分かりませんが、セットアップが何とかしていないと思います。 Eclipseを削除したり、Google Cloud SDKをアンインストールしたり、Javaをアンインストールしたり、Eclipseでワークスペースをリセットしたり、すべてを再インストールして再設定したりすることで、この問題を解決できました。だから私は同じ問題を抱えている誰かを助けることができれば嬉しいです

関連する問題