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();
}
}
嗯,现在我正在考虑它,有一个一致的str一般来说,开放可能不是最好的方法。应用程序如何做,我认为这是更普通的推送通知方式,而不是WSS,是吗?任何方式,我可以捎带只是在那些?我的意思是,塔斯克如何抢占? – seaders
Android应用程序使用标准的GCM推送通知。我不确定塔斯克如何抓住这些,但我会检查与Android的人。我可能会为其他应用程序实现一个使用GCM推送通知的事情,但尚未完成此任务。 –