用 Socket.D 替代原生 WebSocket 做前端开发
socket.d.js 是基于 websocket 包装的 socket.d 协议的实现。就是用 ws 传输数据,但功能更强大。
功能 | 原生 websocket | socket.d | 说明 |
---|---|---|---|
listen | 有 | 有 | 监听消息 |
send | 有 | 有 | 发消息 |
sendAndRequest | 无 | 有 | 发消息并接收一个响应(类似于 http) |
sendAndSubscribe | 无 | 有 | 发消息并接收多个响应(也叫订阅) |
event(or path) | 无 | 有 | 消息有事件或路径(可对消息,进行业务路由) |
meta(or header) | 无 | 有 | 消息有元信息或头信息(可为数据,标注业务语义) |
下面感受下开发方面的差异!
1、客户端示例代码
使用时,可以根据自己的业务对原生接口包装,进一步简化使用。
<script src="js/socket.d.js"></script> <script> async function init(){ //构建事件监听 const eventListener = await SocketD.newEventListener().doOnMessage((s,m)=>{ //监听所有消息(可能不需要) }).doOn("/im/user.upline", (s,m)=>{ //事件的应用 //监听用户上线 let user_id = m.meta("user_id"); }).doOn("/im/user.downline", (s,m)=>{ //监听用户下线 let user_id = m.meta("user_id"); //元信息的应用 }); //创建单例 window.clientSession = SocketD.createClient("sd:ws://127.0.0.1:8602/?u=a&p=2")
.listen(eventListener) .open(); } function join(){ clientSession.sendAndRequest("/user/join", SocketD.newEntity()).thenReply(r->{ //加入成功 }); } init(); </script>
Socket.D 有三个发消息的接口:
接口 | 说明 |
---|---|
send | 像 websocket。多了事件与元信息属性 |
sendAndRequest | 像 http |
sendAndSubscribe | 像 reactive stream 。多了事件与元信息属性 |
2、服务端示例代码(用 java 演示)
public class Demo { public static void main(String[] args) throws Throwable { List<Session> userSessions = new ArrayList<Session>(); //创建监听器 Listener listener = new EventListener().doOnOpen(s->{ //鉴权 if("a".equals(s.param("u")) == false){ s.close(); }else{ //加入用户表 s.attrPut("user_id", s.param("u")); userSessions.add(s); } }).doOn("/user/join", (s,m)->{ if(m.isRequest()){ s.reply(m, new StringEntity()); } for(Session s1: userSessions){ //告诉所有用户,有人上线 s1.send("/im/user.upline", new StringEntity().metaPut("user_id"), s.attr("userId")); } }); //启动服务 SocketD.createServer("sd:ws") .config(c -> c.port(8602)) .listen(listener) .start(); } }
3、Socket.D 是什么东东?
Socket.D 是一个基于“事件”和“语义消息”“流”的网络应用层协议(听起来好像很 ao 口)。支持 tcp, udp, ws, kcp 传输。有用户说,“Socket.D 之于 Socket,尤如 Vue 之于 Js、Mvc 之于 Http”。
协议之所有强大,有三个关键基础因素:
- 事件
- 语义消息
- 流
它的帧码结构:
[len:int][flag:int][sid:str(<64)][\n][event:str(<512)][\n][metaString:str(<4k)][\n][data:byte(<16m)]
因为是应用层协议,所以可以建立在任意传输层协议之上。比如 websocket。
4、开源仓库

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
马化腾回应早期微信“偷窥”用户相册:图片缓存加速造成的误会
据 CSDN 报道,针对早前有软件工程师爆料称包括微信等在内的多款国民级 App 在后台反复读取用户相册一事,1月5日,马化腾独家回应:“应该是21年10月的事了,图片缓存加速造成的误会,后面应该用 iOS 新的解决卡顿的 API 解决了”。并特别表示,“可以帮忙辟谣”。 事情的前因还要追溯到 2021 年 10 月 8 日,当时苹果 iOS 15 刚刚推出隐私新特性 「记录 App 活动」,对所有 App 的隐私读取行为进行了 7 天的监控,并使用 App Privacy Insights 对记录进行读取。 数码博主、软件开发工程师 @Hackl0us 发现微信在用户未主动激活 App 的情况下,在后台数次读取用户相册,每次读取时间长达 40 秒 至 1 分钟不等。
- 下一篇
欢迎 Tianai-Captcha 加入 Dromara 开源社区,可能是开源界最好用的行为验证码工具
作者介绍 95后大龄程序员,一名野生的民间技术爱好者,15年学习编程技术,迫于生计于17年就职于某电商公司, 在从业生涯中,本项目2020年发布后,后续也是改改停停,自古闲人出金货,也许有一天笔者自由了,会好好的完善这套框架。 引言: 譬如在今之网络世界,为保障资讯之安全,凡入网之人或事,多须经由验证之法以证实己身之真实性。是以,验证码乃必不可少之一环也。其重要性备矣,具诚信者无不体知。 朕观网络之变幻,验证码多以随机字母构成者为众所周知。然而,此类验证码对于一般用户而言,尤其易于应用。盖因滑动、点选等高级验证码,虽能提供更加友好之体验,然然不易于普通用户之应用。 吾观察于平民百姓,多未涉猎于技术深处,对于复杂之滑动、点选类验证码而言,或存不解其所在。且诸多普通用户或使用传统设备,或因技术限制而难以适用此等新颖验证码。是以,此类验证码对于普罗百姓而言,未免难以为继。 嗟乎!有智者闻我国民之难,乃发明滑动及点选验证码以应民需,其善心可嘉。彼将此等验证码开源,使广大百姓得以轻松接纳,实属可喜可贺。 滑动及点选验证码之开源,如一泓清泉,涤荡网络之隐忧。于此,一般百姓不复为验证码所困,得以轻松...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS8安装Docker,最新的服务器搭配容器使用
- Linux系统CentOS6、CentOS7手动修改IP地址
- 2048小游戏-低调大师作品
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS8安装MyCat,轻松搞定数据库的读写分离、垂直分库、水平分库
- CentOS8编译安装MySQL8.0.19
- CentOS6,CentOS7官方镜像安装Oracle11G
- CentOS7,8上快速安装Gitea,搭建Git服务器
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- MySQL8.0.19开启GTID主从同步CentOS8