2015-05-22 65 views
0

Pushbullet的令人敬畏的服务有一个websocket流,您可以订阅,然后听取推送到您的设备,这正是我想要的。我希望我的应用程序能够连接到消息流,并根据他们所说的去做东西。在Android上连接到Pushbullet的Secure Websocket

我试过使用https://github.com/andrepew/Java-WebSocket/tree/1.3.0-Android-SSL-Fix(从https://github.com/TooTallNate/Java-WebSocket分叉),但我没有运气。有点超时后,连接响应回来与

onClose -1, draft [email protected] refuses handshake, false 

05-22 03:24:30.709 15423-15904 java.lang.NullPointerException: ssl == null 
05-22 03:24:30.710 15423-15904 com.android.org.conscrypt.NativeCrypto.SSL_read_BIO(Native Method) 
05-22 03:24:30.710 15423-15904 com.android.org.conscrypt.OpenSSLEngineImpl.unwrap(OpenSSLEngineImpl.java:477) 
05-22 03:24:30.710 15423-15904 javax.net.ssl.SSLEngine.unwrap(SSLEngine.java:1006) 

我的代码来获取的(没有我的访问令牌......)甚至尝试了“信任所有主机“建议破解,

private void createConnection() 
{ 
    URI uri = URI.create("wss://stream.pushbullet.com/websocket/" + pushAT); 

    final WebSocketClient mWebSocketClient = new WebSocketClient(uri) { 
     @Override 
     public void onOpen(ServerHandshake serverHandshake) { 
      Log.d(TAG, "onOpen " + serverHandshake); 
     } 

     @Override 
     public void onMessage(String s) { 
      Log.d(TAG, "onMessage " + s); 
     } 

     @Override 
     public void onClose(int i, String s, boolean b) { 
      Log.d(TAG, "onClose " + i + ", " + s + ", " + b); 
     } 

     @Override 
     public void onError(Exception e) { 
      Log.d(TAG, "onError " + e); 
      e.printStackTrace(); 
     } 
    }; 

    Log.d(TAG, "Connecting to " + uri); 
    trustAllHosts(mWebSocketClient); 

    mWebSocketClient.connect(); 
    Log.d(TAG, "Connecting to " + uri); 
} 

public void trustAllHosts(WebSocketClient wsc) { 
    // Create a trust manager that does not validate certificate chains 
    TrustManager[] trustAllCerts = new TrustManager[]{new X509TrustManager() { 
     public java.security.cert.X509Certificate[] getAcceptedIssuers() { 
      return new java.security.cert.X509Certificate[]{}; 
     } 

     public void checkClientTrusted(X509Certificate[] chain, 
             String authType) throws CertificateException { 
     } 

     public void checkServerTrusted(X509Certificate[] chain, 
             String authType) throws CertificateException { 
     } 
    }}; 


    // Install the all-trusting trust manager 
    try { 
     SSLContext sc = SSLContext.getInstance("TLS"); 
     sc.init(null, trustAllCerts, new java.security.SecureRandom()); 
     wsc.setWebSocketFactory(new DefaultSSLWebSocketClientFactory(sc)); 
    } catch (Exception e) { 
     e.printStackTrace(); 
    } 
} 

回答

1

从这个错误我只能猜测它可能有一些问题与SSL。还有一个替代(未记录)的流式端点,您可以尝试这可能有助于调试此问题。如果您向https://stream.pushbullet.com/streaming/ACCESS_TOKEN_HERE发出请求,它将返回一个分块的HTTP响应,直到断开连接为止。如果你能弄清楚如何读取这个流式响应(许多http客户端可以做到这一点),那么至少该部分起作用,它只是你的websocket库。

您可以使用命令行中的流媒体事件与curl --no-buffer。连接后应立即看到一条nop消息。

+0

嗯,现在我正在考虑它,有一个一致的str一般来说,开放可能不是最好的方法。应用程序如何做,我认为这是更普通的推送通知方式,而不是WSS,是吗?任何方式,我可以捎带只是在那些?我的意思是,塔斯克如何抢占? – seaders

+0

Android应用程序使用标准的GCM推送通知。我不确定塔斯克如何抓住这些,但我会检查与Android的人。我可能会为其他应用程序实现一个使用GCM推送通知的事情,但尚未完成此任务。 –

1

您可能更容易在Android上使用流式传输(长期存在的HTTP连接)而不是WebSocket。以下是我在Android上为此工作的一些示例代码:

final URL url = new URL("https://stream.pushbullet.com/streaming/" + <USER_API_KEY>); 
final HttpURLConnection connection = (HttpURLConnection) url.openConnection(); 
connection.setReadTimeout(38000); 
connection.setConnectTimeout(8000); 
connection.setRequestMethod("GET"); 
connection.setDoInput(true); 

L.i("Connecting to stream server"); 

connection.connect(); 

final int responseCode = connection.getResponseCode(); 
if (responseCode != 200) { 
    throw new QuietException("Unable to connect to stream, server returned " + responseCode); 
} 

final InputStream inputStream = connection.getInputStream(); 

try { 
    final BufferedReader stream = new BufferedReader(new InputStreamReader(inputStream)); 

    final String line = stream.readLine(); 
    final JSONObject message = new JSONObject(line); 
    // And now you can do something based on this message 
} finally { 
    inputStream.close(); 
} 

这会在您的应用程序打开时工作得很好。如果你想一直收到消息,那就更难了。您需要通过GCM接收邮件,这意味着要创建一个设备让我们将这些邮件发送给您的应用。如果这是您需要的,我建议发邮件给[email protected]获取更多帮助。

0

据我所知,从错误中可以看出,你使用的是比较旧的Draft_10。

你应该使用当前的草案[Draft_17]是这样的:

final WebSocketClient mWebSocketClient = new WebSocketClient(uri, new Draft_17()) { 

,并加入到进口:

import org.java_websocket.drafts.Draft_10; 

如果你有兴趣,你可能会发现更多的草案在这里:

https://github.com/TooTallNate/Java-WebSocket/wiki/Drafts