IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> websocket -> 正文阅读

[网络协议]websocket

一:

1、webosocket与socket

?websocket属于应用层协议
?socket属于传输层协议
?socket相当于一组接口,当两台主机进行通信时候,必须通过此API利用TCP/IP协议建立连接?

2、websocket与http

websocket是HTTP5新增的协议,实现了浏览器和服务器全双工通信,能节省服务器资源和带宽实现实时通信
两者基于TCP/IP,且都是应用层协议
websocket是全双工,http是单向的
websocket需要握手建立连接

二:
基于tomcat7.5+对websocket的实现
服务器端API,访问:ws://[IP或域名]:[server端口]/websocket

@ServerEndpoint(value = "/websocket")
public class WebSocketSync {

? ? private static CopyOnWriteArraySet<WebSocketSync> webSocketSet = new CopyOnWriteArraySet<WebSocketSync>();

? ? private Session session;

? ? @OnOpen
? ? public void OnOpen(Session session){
? ? ? ? this.session = session;
? ? ? ? webSocketSet.add(this);
? ? }

? ? @OnClose
? ? public void OnClose(){
? ? ? ? this.session = session;
? ? ? ? webSocketSet.remove(this);
? ? }

? ? @OnError
? ? public void OnError(Session session, Throwable error){
? ? ? ? logger.error(error.getMessage());
? ? }

? ? @OnMessage
? ? public void OnMessage(String msg){
? ? ? ? logger.info("收到消息:{}", msg);
? ? }

? ? public void sendMessage(String message) {
? ? ? ? for (WebSocketSync webSocketSync : webSocketSet){
// ? ? ? ? ? ?logger.info("广播消息:{}",message);
? ? ? ? ? ? try {
? ? ? ? ? ? ? ? webSocketSync.session.getBasicRemote().sendText(message);
? ? ? ? ? ? } catch (IOException e) {
? ? ? ? ? ? ? ? e.printStackTrace();
? ? ? ? ? ? }
? ? ? ? }}
}

客户端API

var ws = new WebSocket(“ws://[IP或域名]:[server端口]/websocket”);?
? ? ws.onopen = function(){
? ? ? ? ws.send("Test!");
? ? };
? ? ws.onmessage = function(evt){
? ? ? ? console.log(evt.data);
? ? ? ? ws.close();
? ? };
? ? ws.onclose = function(evt){
? ? ? ? console.log("WebSocketClosed!");
? ? };
? ? ws.onerror = function(evt){
? ? ? ? console.log("WebSocketError!");
? ? };

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2021-07-24 11:51:07  更:2021-07-24 11:52:43 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/27 13:49:56-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码
数据统计