位置: 编程技术 - 正文

socket.io学习教程之深入学习篇(三)(socketio视频教程)

编辑:rootadmin

推荐整理分享socket.io学习教程之深入学习篇(三)(socketio视频教程),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:socket.io.js,socket.io api,socket入门,socket入门,socketio视频教程,socketio视频教程,socket 教程,socket怎么学,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

socket.io提供了基于事件的实时双向通讯,本文深入的介绍了socket.io,下面来看看详细的内容吧。

静态文件

socket.io默认情况下会通过socket.io-client包提供socket.io.min.js和socket.io.js.map下载

运行实例app.js

浏览器访问 实例化时传入控制参数serveClient值false

方法2: 调用函数serverClient

如果在调用函数前服务已绑定http.Server,该方法将不起作用

禁用后再次访问将提示{"code":0,"message":"Transport unknown"}

修改静态文件路径

socket.io.js路径可以改变,其默认路径为/socket.io。

实例化时传参

调用函数path

如果在调用函数前服务已绑定http.Server,该方法将不起作用

安全策略

socket.io提供了两种安全策略

allowRequest

函数allowRequest有两个参数,第一个参数为收到的握手包(http.request)对象,作为判断依据, success), err是错误对象,success为boolean, false表示阻止建立连接

前端请求带上token

后端allowRequest根据token判断是否继续

origins

可以对源进行限制

1、实例化时限制源

2、origins函数设置源

origins函数有两种形式

origins(string) : 设置运行的源

origins(string, fn(err, success)) : 通过函数判断源是否允许

socket.io学习教程之深入学习篇(三)(socketio视频教程)

名称空间

名称空间用来对服务端/客户端的连接隔离,有些地方,也称呼名称空间(namespace)为通道(channel)。下面举例对其意义进行说明

我们需要实现一个协同应用,这个应用有两个功能:

协同编辑: 多个用户可以同时编辑一个文档 消息: 用户间可以发送消息

用socket.io实现这个应用,有如下几种形式

1、完全独立: 协同编辑有一个独立服务edit.socket.test ,消息系统一个独立服务message.socket.test

2、名称空间: 只运行一个独立服务,通过名称空间进行隔离

3、事件名约定: 通过为事件名添加进行隔离

通过事件名约定程序的侵入性太大,不利于拆分和重组,不推荐。 而完全独立的模式需要使用两个socket连接,即浪费浏览器允许的并发连接数,又更多消耗服务器资源。使用名称空间即能实现很好的隔离,又不会对资源造成浪费。

默认名称空间

socket.io实例化时自动绑定路径为/的名称空间

中间件

socket.io的名空间通过use注册中间件,中间件在客户端与服务端建立连接成功后,connet事件派发前调用一次。

利用中间件数据校验

利用中间件提取或转换数据 io.use((socket, next) => { getInfo(socket.request.query.id, (err, data) => { if (err) return next(err) socket.custom = data next() }) })

与allowRequest对比

allowRequest可以进行一些校验,提取,为什么还要需要中间件&#;

allowRequest传入的http.request实例,而中间件出入数据socket实例,socket实例包含request实例,且有更多信息 中间件直接支持多个异步流程嵌套,而allowRequest需要自己实现

与connection事件对比

connection事件也传入socket,也可以进行数验,提取,为什么还要需要中间件&#;

中间件直接支持多个异步流程嵌套,而allowRequest需要自己实现 中间件成功后到connection事件发送成功前,socket.io还做了一些工作,比如把socket实例添加到connected对象中,加入聊天室等。如果因为权限中断连接,在中间件中处理更省资源.

聊天室

聊天室是对当前连接的socket集合根据特定规则进行归组,方便群发消息。可以类比QQ群的概率.

默认聊天室

每个socket在连接成功后会自动创建一个默认个聊天室,这个聊天室的名字是当前socket的id,可以通过默认聊天室实现向特定用户发送消息

消息发送

应答消息

普通消息不需要回应,而应答消息提供了应答机制

压缩

socket.compress(true)启用压缩,调用后当前连接的所有数据在传递给客户端前都会进行压缩

volatile标志

socket.io在正常情况下对发送的消息进行追踪,确保消息发送成功,而设置volatile后发送消息,socket.io不会对消息追踪,消息可能丢失

分类

总结

标签: socketio视频教程

本文链接地址:https://www.jiuchutong.com/biancheng/379446.html 转载请保留说明!

上一篇:socket.io学习教程之基本应用(二)(socket怎么用)

下一篇:node.js 抓取代理ip实例代码(nodejs 代理请求)

  • 待认证进项税额和待抵扣进项税额的区别
  • 二手房交易需缴纳哪些费用
  • 个体户收现金可以开发票吗
  • 公司汽车的折旧费可以扺税吗
  • 每月10万不要交税从什么时候开始
  • 资产负债表上的资产是原值还是净值
  • 投资性房地产处置时为什么要结转其他综合收益
  • 分包管理费取费标准
  • 应收未收的利息如何处理
  • 报税报错了怎么办?
  • 外购货物用于职工福利企业所得税怎么调整
  • 资产负债表应收账款是负数怎么回事
  • 企业借款利息税前扣除怎么算
  • 税法对弥补亏损的规定是什么?
  • 企业公益救济性工作总结
  • 跨年度专用发票如何开红字发票
  • mac死机什么原因
  • 金蝶软件测试笔试题及答案
  • 以前年度的账错了怎么办
  • 成本核算的意义是什么
  • php数组函数题目
  • 勃朗峰峡谷
  • 认缴没有实缴怎么做账
  • php获取手机型号
  • 【历史上的今天】4 月 7 日:IBM System/360 问世;以太网的发明者诞生;第一个 RFC 文档发布
  • show version命令详解
  • 股东投资款超过注册资金的案例
  • 暂估入库少了
  • 退税没有退的部分怎么做账
  • mongodb数据库基本操作
  • 小规模附加税减免政策2023
  • 社保交费银行对账怎么办
  • 福利部门领用材料计入什么科目
  • 购入交易性金融资产的相关税费计入
  • 报销差旅费的进项税额
  • 合伙制律师事务所和个人律师事务所
  • 多缴附加税退税怎么做账
  • 分销佣金账务处理流程
  • 亏损做t计算方法
  • 印花税计入相关资产成本吗
  • 融资租赁固定资产不属于筹资活动
  • 长期待摊费用属于利润表项目吗
  • 专票入账用哪一联
  • 计提本月工资社保怎么扣
  • 固定资产多少钱标准
  • 个人发票单位能做账用吗
  • 应收应付账款如何清理
  • 毛利体现的是什么
  • 增值税普通发票查询
  • 房地产核算
  • 终端运行mysql
  • ubuntu sudo apt-get install
  • centos rpm包存放位置
  • MySQL 5.7.14 net start mysql 服务无法启动-“NET HELPMSG 3534” 的奇怪问题
  • Python MySQL进行数据库表变更和查询
  • mysql2002解决办法
  • macos 修改mac
  • bios屏蔽nvme
  • win10周年更新版是什么意思
  • windows xp 2021 r3
  • xp系统磁盘检查进不去
  • win10系统资源
  • win8系统怎么重新安装系统
  • winxp系统怎么设置开机密码
  • mac配置selenium
  • windows8的ie浏览器在哪
  • win7系统重装后u盘读不出来
  • win10更新中重启会怎么样
  • 惠普笔记本的BIOS键
  • linux命令eof
  • dosbox批处理
  • nodejs爬取数据
  • node服务器部署
  • Linux bash Shell中的变量类型详解
  • android开发菜鸟教程
  • python讲解
  • 浙江职称评审网址官网
  • 社保逾期未申报会造成什么影响,要怎么处理
  • 地税局开发票流程?
  • 云南国税申报
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设