java socket用例_WebSocket 的简单用例

本文介绍了WebSocket相对于HTTP的优点,并提供了使用Java实现的WebSocket服务端和JavaScript客户端的简单示例,展示了如何建立连接、发送和接收消息。WebSocket提供了更短的包头、全双工通信、有状态连接和更好的二进制支持,是现代实时通信的优选方案。
摘要由CSDN通过智能技术生成

7acc07bcf2d07ecfe93154aacd04b2dd.png

WebSoket 相较于 HTTP ,有以下优点:

1、包头更短。在建立长连接等需要轮询发送请求确认连接状态的情况下,包头的减小使得服务端压力更小,节省服务端资源。在不包含扩展的情况下,对于服务器到客户端的内容,此头部大小只有2至10字节(和数据包长度有关);对于客户端到服务器的内容,此头部还需要加上额外的4字节的掩码。相对于HTTP请求每次都要携带完整的头部,此项开销显著减少了。

2、全双工。虽然 HTTP 本身便是基于 TCP 协议的,但是 HTTP 的 请求-应答 机制先天限制了服务端主动向客户端发送数据。

3、有状态连接。与HTTP不同的是,Websocket需要先创建连接,这就使得其成为一种有状态的协议,之后通信时可以省略部分状态信息。而HTTP请求可能需要在每个请求都携带状态信息。

4、更好的二进制支持。Websocket定义了二进制帧,相对HTTP,可以更轻松地处理二进制内容。

5、可以支持扩展。Websocket定义了扩展,用户可以扩展协议、实现部分自定义的子协议。如部分浏览器支持压缩等。

6、更好的压缩效果。相对于HTTP压缩,Websocket在适当的扩展支持下,可以沿用之前内容的上下文,在传递类似的数据时,可以显著地提高压缩率。

使用 JAVA 写一个服务端:

packagelearning.websocket;importorg.java_websocket.WebSocket;importorg.java_websocket.handshake.ClientHandshake;importorg.java_websocket.server.WebSocketServer;importjava.net.InetSocketAddress;importjava.net.UnknownHostException;public class MyWebSocketServer extendsWebSocketServer {public MyWebSocketServer(int port) throwsUnknownHostException {super(newInetSocketAddress(port));

System.out.println("webSocketServer started at port: " +port);

}

@Overridepublic voidonOpen(WebSocket webSocket, ClientHandshake clientHandshake) {

System.out.println("new connect with : " +webSocket.getRemoteSocketAddress().getAddress());

}

@Overridepublic void onClose(WebSocket webSocket, int i, String s, booleanb) {

System.out.println("connect closed : " +webSocket.getRemoteSocketAddress().getAddress());

}

@Overridepublic voidonMessage(WebSocket webSocket, String s) {

System.out.println("new Message : " +s);

webSocket.send(" server has recived message : " +s);

}

@Overridepublic voidonError(WebSocket webSocket, Exception e) {

}

@Overridepublic voidonStart() {

}public static void main(String[] args) throwsException {new MyWebSocketServer(9000).start();

}

}

JS 写一个客户端:

functionWebSocketTest(msg) {if ("WebSocket" inwindow) {var ws = new WebSocket("ws://localhost:9000");

ws.onopen= function() {

ws.send(msg);

};

ws.onmessage= function(evt) {

alert("recive message : " +evt.data);

};

ws.onclose= function() {

alert("connection closed");

};returnws;

}else{

alert("您的浏览器不支持 WebSocket!");

}

}var ws = WebSocketTest('build connect');if (ws.readyState == 1) {

ws.send("斯巴达!");

}else{

setTimeout('ws.send("斯巴达!")', 500);

}

c6fb0878649c22e14af1efdc466cb998.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用 C 语言和 WebSocket Secure (wss) 服务端的示例代码: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <sys/socket.h> #include <arpa/inet.h> #include <openssl/ssl.h> #include <openssl/err.h> #define SERVER_PORT 8080 #define SERVER_CERT "server.crt" #define SERVER_KEY "server.key" int main() { SSL_CTX *ctx; SSL *ssl; int server_fd, client_fd; struct sockaddr_in server_addr, client_addr; socklen_t client_len; char buffer[1024]; // 创建 SSL 上下文 SSL_library_init(); ctx = SSL_CTX_new(TLS_server_method()); if (ctx == NULL) { perror("SSL_CTX_new"); exit(EXIT_FAILURE); } // 加载服务器证书和私钥 if (SSL_CTX_use_certificate_file(ctx, SERVER_CERT, SSL_FILETYPE_PEM) <= 0) { perror("SSL_CTX_use_certificate_file"); exit(EXIT_FAILURE); } if (SSL_CTX_use_PrivateKey_file(ctx, SERVER_KEY, SSL_FILETYPE_PEM) <= 0 ) { perror("SSL_CTX_use_PrivateKey_file"); exit(EXIT_FAILURE); } // 创建服务器套接字 server_fd = socket(AF_INET, SOCK_STREAM, 0); if (server_fd == -1) { perror("socket"); exit(EXIT_FAILURE); } // 绑定服务器地址和端口 memset(&server_addr, 0, sizeof(server_addr)); server_addr.sin_family = AF_INET; server_addr.sin_addr.s_addr = INADDR_ANY; server_addr.sin_port = htons(SERVER_PORT); if (bind(server_fd, (struct sockaddr *)&server_addr, sizeof(server_addr)) == -1) { perror("bind"); exit(EXIT_FAILURE); } // 监听客户端连接 if (listen(server_fd, 10) == -1) { perror("listen"); exit(EXIT_FAILURE); } printf("Server is listening on port %d...\n", SERVER_PORT); while (1) { // 接受客户端连接 client_len = sizeof(client_addr); client_fd = accept(server_fd, (struct sockaddr *)&client_addr, &client_len); if (client_fd == -1) { perror("accept"); continue; } // 创建 SSL 对象 ssl = SSL_new(ctx); SSL_set_fd(ssl, client_fd); // SSL 握手 if (SSL_accept(ssl) <= 0) { perror("SSL_accept"); goto close_ssl; } printf("Client connected: %s:%d\n", inet_ntoa(client_addr.sin_addr), ntohs(client_addr.sin_port)); while (1) { // 接收客户端消息 memset(buffer, 0, sizeof(buffer)); int len = SSL_read(ssl, buffer, sizeof(buffer)); if (len <= 0) { if (len == 0) { printf("Client disconnected.\n"); } else { perror("SSL_read"); } break; } printf("Received message from client: %s\n", buffer); // 发送回复消息给客户端 char *reply = "Hello, client!"; if (SSL_write(ssl, reply, strlen(reply)) <= 0) { perror("SSL_write"); break; } } close_ssl: // 关闭 SSL 对象和客户端套接字 SSL_shutdown(ssl); SSL_free(ssl); close(client_fd); } // 关闭服务器套接字和 SSL 上下文 close(server_fd); SSL_CTX_free(ctx); return 0; } ``` 这个例子创建了一个使用 wss 协议的服务器,监听 8080 端口。客户端连接后,服务器会接收客户端发送的消息并回复 "Hello, client!"。您需要将服务器证书和私钥的文件名替换为您自己的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值