国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

koa socket即時通訊的示例代碼

來源:懂視網 責編:小采 時間:2020-11-27 22:08:10
文檔

koa socket即時通訊的示例代碼

koa socket即時通訊的示例代碼:前言 http的特點是一問一答,而即時通訊是需要雙向通信的,這樣以前的即時通信只能使用輪詢的方式通過周期性的ajax請求獲取數據,直到websocket出現,就完美實現了雙向通信 一 即時通訊方式簡介 段輪詢 前臺使用setInterval進行定時請求后臺,這樣無疑
推薦度:
導讀koa socket即時通訊的示例代碼:前言 http的特點是一問一答,而即時通訊是需要雙向通信的,這樣以前的即時通信只能使用輪詢的方式通過周期性的ajax請求獲取數據,直到websocket出現,就完美實現了雙向通信 一 即時通訊方式簡介 段輪詢 前臺使用setInterval進行定時請求后臺,這樣無疑

前言

http的特點是一問一答,而即時通訊是需要雙向通信的,這樣以前的即時通信只能使用輪詢的方式通過周期性的ajax請求獲取數據,直到websocket出現,就完美實現了雙向通信

一 即時通訊方式簡介

段輪詢

前臺使用setInterval進行定時請求后臺,這樣無疑非常浪費性能

長輪詢和長連接(html5的EventSource)

客服端連接一次,服務端不斷開連接,服務端接收到新消息就發送給前臺,客服端和服務端保持一直連接,缺點是只有服務端向客服端輸出

websocket

websocket不再是走http協議,而是升級為websocket協議,說到底就是走應用層協議(tcp),實現雙向通信,缺點是兼容性問題(ie11)

socket.io

上面的方式都存在一定問題,自然就有人封裝一套完美的解決方案,socket.io就是集合了上面幾種方案的另一種解決方案

二 即時通信實現

客服端

引入包:<script src="https://cdn.socket.io/socket.io-1.2.1.js";></script>

服務端和客服端通過on和emit進行交互

  1. emit表示發送,事件名自定義,另一端用on進行接收
  2. on表示接受,類似jq綁定事件,事件名對應emit事件名
  3. connect,disconnect是連接和斷開事件
 // 建立連接
 var socket= io('http://localhost:80')
 // on表示接收
 // emit表示發送
 socket.on('connect', function () {
 console.log('連接上了')
 // 登錄,同步前后端信息
 // 請求后端login接口,寫入socketid
 socket.emit('login', {
 // 身份標識,可以是時間戳或者唯一id,最要用來回去socketid進行私聊
 id: username
 })
 })


 // 發送消息,這里可以用發送事件進行消息發送
 socket.emit('sendMsg', {
 newAccount: 'xxxxxx'
 })
 
 // 接收消息
 socket.on('msg1', function (data) {
 // 可以對數據進行渲染
 console.log(data)
 
 })
 socket.on('allmessage', function (data) {
 // 接收所有人消息
 console.log(data);

 })
 
 // 表示連接斷開了
 socket.on('disconnect', function () {
 console.log('聊天服務器斷開了')
 })

服務端(koa+koa-socket)

安裝koa-socket

npm i koa2 koa-socket -S
 const IO = require('koa-socket')
 const Koa = require('koa2')
 const io = new IO()
 
 const app = new Koa()
 
 // 將socket和app關聯
 io.attach(app)
 // 和客服端進行連接
 io.on('connection', (context) => {
 console.log('連接上了')
 })
 // 接收消息
 io.on('sendMsg', function (context) {
 //console.log(context.data)
 // 向客服端實時發送消息
 io.broadcast('msg1', '我是服務器來的')

 // 廣播,所有人消息
 io.broadcast('allmessage', context.data.newAccount)
 })

 // 處理登陸同步信息
 io.on('login', context => {
 let id = context.data.id;
 console.log(context);
 });

總結

上面就是koa-socket使用的簡單介紹,只實現了簡單的消息推送和接收,后面還有私聊和群發,其原理是獲取到每個用戶的socketid,發送消息時對應發送,后面再進行更新

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

koa socket即時通訊的示例代碼

koa socket即時通訊的示例代碼:前言 http的特點是一問一答,而即時通訊是需要雙向通信的,這樣以前的即時通信只能使用輪詢的方式通過周期性的ajax請求獲取數據,直到websocket出現,就完美實現了雙向通信 一 即時通訊方式簡介 段輪詢 前臺使用setInterval進行定時請求后臺,這樣無疑
推薦度:
標簽: 代碼 so 的例子
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 国产国语一级毛片中文 | 国产精品麻豆视频 | 欧美综合亚洲 | 国产欧美日韩精品在线 | 亚洲伊人久久大香线蕉综合图片 | 国产欧美在线观看不卡 | 亚洲视频入口 | 在线视频观看国产 | 免费看黄视频网站 | 国产激情视频一区二区三区 | 精品国产欧美一区二区五十路 | 亚洲国产精品久久久久久 | 日本一区二区三区免费看 | 国产日韩欧美亚洲综合 | 真人一级一级毛片免费观看 | 日本福利片国产午夜久久 | 久久婷婷久久一区二区三区 | 亚洲精品高清国产一久久 | 国产视频一区二区在线播放 | 国产成人亚洲综合一区 | 欧美精品一区二区三区免费观看 | 欧美1区2区3区 | 亚洲国产精品免费 | 国产一区二区三区视频在线观看 | 欧美精品一区二区精品久久 | 精品成人一区二区三区免费视频 | 一区一精品 | 国产成人精品一区二区免费 | 在线亚洲欧美日韩 | 欧美亚洲综合在线观看 | 国产精品亚洲一区二区三区在线播放 | 国产 日韩 欧美 在线 | 日韩欧美片 | 欧美另类网站 | 久久综合精品国产一区二区三区无 | 日韩美女一区二区三区 | 成人一级片在线观看 | 国产一区欧美二区 | 一区二区三区视频在线 | 国产国语高清在线视频二区 | 日本色图在线观看 |