【问题标题】:NullPointerException on Opening SSL Socket to socket-io server向 socket-io 服务器打开 SSL 套接字时出现 NullPointerException
【发布时间】:2014-12-12 14:50:40
【问题描述】:

我正在尝试在 Gottox SocketIO 的帮助下从 Android 应用程序连接到 Socket IO。 它在低于 4.4 的 android 版本上运行良好,但在 V4.4.2 上总是给我一个 NullPointerException!

连接建立如下:

    SSLContext ssl_context = null;
    try {
        ssl_context = SSLContext.getInstance("TLS", "HarmonyJSSE"); 
    } catch (NoSuchAlgorithmException |  KeyManagementException | NoSuchProviderException  e) { //
        Log.e(LOGIDENT,e.getMessage());
    }
_socket = new SocketIO("SOCKETURI");
_socket.connect(new IOCallback() { ... });

这是 StackTrace:

12-12 15:41:13.355  21152-21308/com.mynamespace W/System.err﹕ java.lang.NullPointerException
12-12 15:41:13.375  21152-21308/com.mynamespace W/System.err﹕ at com.android.org.conscrypt.SSLSocketWrapper.initTransportLayer(SSLSocketWrapper.java:48)
12-12 15:41:13.380  21152-21308/com.mynamespace W/System.err﹕ at com.android.org.conscrypt.SSLSocketImpl.init(SSLSocketImpl.java:186)
12-12 15:41:13.380  21152-21308/com.mynamespace W/System.err﹕ at com.android.org.conscrypt.SSLSocketImpl.<init>(SSLSocketImpl.java:111)
12-12 15:41:13.385  21152-21308/com.mynamespace W/System.err﹕ at com.android.org.conscrypt.SSLSocketWrapper.<init>(SSLSocketWrapper.java:37)
12-12 15:41:13.390  21152-21308/com.mynamespace W/System.err﹕ at com.android.org.conscrypt.SSLSocketFactoryImpl.createSocket(SSLSocketFactoryImpl.java:91)
12-12 15:41:13.400  21152-21308/com.mynamespace W/System.err﹕ at com.android.okhttp.Connection.upgradeToTls(Connection.java:999)
12-12 15:41:13.405  21152-21308/com.mynamespace W/System.err﹕ at com.android.okhttp.Connection.connect(Connection.java:955)
12-12 15:41:13.415  21152-21308/com.mynamespace W/System.err﹕ at com.android.okhttp.internal.http.HttpEngine.connect(HttpEngine.java:411)
12-12 15:41:13.430  21152-21308/com.mynamespace W/System.err﹕ at com.android.okhttp.internal.http.HttpEngine.sendSocketRequest(HttpEngine.java:343)
12-12 15:41:13.440  21152-21308/com.mynamespace W/System.err﹕ at com.android.okhttp.internal.http.HttpEngine.sendRequest(HttpEngine.java:289)
12-12 15:41:13.440  21152-21308/com.mynamespace W/System.err﹕ at com.android.okhttp.internal.http.HttpURLConnectionImpl.execute(HttpURLConnectionImpl.java:345)
12-12 15:41:13.440  21152-21308/com.mynamespace W/System.err﹕ at com.android.okhttp.internal.http.HttpURLConnectionImpl.getResponse(HttpURLConnectionImpl.java:296)
12-12 15:41:13.445  21152-21308/com.mynamespace W/System.err﹕ at com.android.okhttp.internal.http.HttpURLConnectionImpl.getInputStream(HttpURLConnectionImpl.java:179)
12-12 15:41:13.450  21152-21308/com.mynamespace W/System.err﹕ at com.android.okhttp.internal.http.HttpsURLConnectionImpl.getInputStream(HttpsURLConnectionImpl.java:246)
12-12 15:41:13.455  21152-21308/com.mynamespace W/System.err﹕ at io.socket.IOConnection.handshake(IOConnection.java:317)
12-12 15:41:13.460  21152-21308/com.mynamespace W/System.err﹕ at io.socket.IOConnection.access$600(IOConnection.java:43)
12-12 15:41:13.460  21152-21308/com.mynamespace W/System.err﹕ at io.socket.IOConnection$ConnectThread.run(IOConnection.java:203)

有人知道这个问题或类似的问题吗?或者是否有可能进入 com.android.okhttp.Connection.upgradeToTls,因为我在任何在线可用的资源中都找不到第 999 行。

【问题讨论】:

    标签: android ssl socket.io android-4.4-kitkat


    【解决方案1】:

    我能够解决这个问题的唯一方法是更新到最新的 Java-WebSocket 并从 Gottox SocketIO 更改 WebsocketTransport 实现以传递新的套接字,而不是根据我的评论使用旧的 DefaultWebSocketFactoryissue 上并在此PR 上提供了解决方案。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-07-08
      • 2012-12-16
      • 2020-04-28
      • 2011-11-28
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多