java websocket client ssl(wss)
来源:互联网 发布:临沂淘宝客服在哪里 编辑:程序博客网 时间:2024/05/22 03:53
1.如何找一个适合自己的websocket客户端?请看http://en.wikipedia.org/wiki/Comparison_of_WebSocket_implementations
2.因为要在android上使用websocket,要求使用wss,这时候我就选择了java_websocket(http://java-websocket.org/)
这个ws客户端对wss支持不好,源码中的wss client 还要使用证书。我的想法是不验证证书。将他的代码稍作修改:
import java.io.BufferedReader;import java.io.File;import java.io.FileInputStream;import java.io.InputStreamReader;import java.net.URI;import java.security.KeyStore;import javax.net.ssl.KeyManagerFactory;import javax.net.ssl.SSLContext;import javax.net.ssl.TrustManagerFactory;import org.java_websocket.WebSocket;import org.java_websocket.client.DefaultSSLWebSocketClientFactory;import org.java_websocket.client.WebSocketClient;import org.java_websocket.handshake.ServerHandshake;class WebSocketChatClient extends WebSocketClient {public WebSocketChatClient( URI serverUri ) {super( serverUri );}@Overridepublic void onOpen( ServerHandshake handshakedata ) {System.out.println( "Connected" );}@Overridepublic void onMessage( String message ) {System.out.println( "got: " + message );}@Overridepublic void onClose( int code, String reason, boolean remote ) {System.out.println( "Disconnected" );System.exit( 0 );}@Overridepublic void onError( Exception ex ) {ex.printStackTrace();}}public class SSLClientExample {
// always verify the host - dont check for certificate final static HostnameVerifier DO_NOT_VERIFY = new HostnameVerifier() { public boolean verify(String hostname, SSLSession session) { return true; } }; /** * Trust every server - dont check for any certificate */ private static void trustAllHosts(AppWebSocketClient appClient) { // 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()); appClient.setWebSocketFactory(new DefaultSSLWebSocketClientFactory(sc)); } catch (Exception e) { e.printStackTrace(); } }public static void main( String[] args ) throws Exception {WebSocket.DEBUG = true;WebSocketChatClient chatclient = new WebSocketChatClient( new URI( "wss://localhost:8887" ) );trustAllHosts(appClient);chatclient.connectBlocking();BufferedReader reader = new BufferedReader( new InputStreamReader( System.in ) );while ( true ) {String line = reader.readLine();if( line.equals( "close" ) ) {chatclient.close();} else {chatclient.send( line );}}}}
- java websocket client ssl(wss)
- 配置JAVA SSL/TLS 之websocket wss交互式认证
- Java-WebSocket wss通信异常
- WebSocket连接wss链接
- 如何让服务端同时支持WebSocket和SSL加密的WebSocket(即同时支持ws和wss)?
- [Java] Netty Websocket Server Javascript Client
- [Java] Netty Websocket Server Javascript Client
- JAVA中SSL证书认证通讯-Client
- Java Client using FTP over SSL (Explicit)
- wokerman websocket搭配https域名 即wss
- skynet中使用websocket和wss
- java|android 使用socket.io-client连接nodejs websocket
- java|android 使用socket.io-client连接nodejs websocket
- WebSocket ActionScript Client
- python websocket client
- websocket 和SSL浅析
- WSS
- 【配置】使用nginx反向代理加密websocket (wss)
- Maven3 安装使用(一)
- eclipse+tomcat+svn版本控制的使用方法
- Stopping MySQL database server: mysqld failed!
- Android NDK开发(2)----- JNI多线程
- 四十条测试你是不是合格的PHP程序员
- java websocket client ssl(wss)
- JavaSE第六十六讲:Java中的动态代理模式详解
- ubuntu下安装ant
- Android之listview为空时显示字符串
- linux目录说明
- c++基础6:堆和栈 内存泄漏 栈溢出
- 字符串删除函数 ltrim() 和 rtrim() 和 trim()
- JSONObject与JSONArray的使用
- json中string类型的datetime格式转换为datetime类型:例string类型"/Date(1242357713797+0800)/" 转为datetime类型"yyyy-MM-dd"