node.js - 微信小程序 +nodejs+socket.io bug
問(wèn)題描述
技術(shù)nodejs
socket.io
微信小程序
源碼server.js
const app = require(’express’)()const http = require(’http’).Server(app)const io = require(’socket.io’)(http)app.use(function(req, res, next) { res.setHeader(’Access-Control-Allow-Origin’, ’*’) res.setHeader(’Access-Control-Allow-Credentials’, true) res.setHeader(’Access-Control-Allow-Methods’, ’POST, GET, PUT, DELETE, OPTIONS’) next()})app.get(’/’, (req, res, next) => { res.send({ code: 200, message: ’Welcome to Chat’ })})io.on(’connection’, socket => { console.log(’a user connected’) socket .broadcast .emit(’connection’, ’恭喜您, 您已經(jīng)連接上了我們的聊天室了, 現(xiàn)在您可以開(kāi)始聊天了’) socket.on(’disconnect’, () => { console.log(’user disconnected’) }) socket.on(’chat message’, msg => { console.log(`message: ${msg}`) io.emit(’chat message’, msg) })})http.listen(3000, () => { console.log(’listening on *:3000’)})
client.js
onLoad(options) { // 頁(yè)面初始化 options為頁(yè)面跳轉(zhuǎn)所帶來(lái)的參數(shù) // 創(chuàng)建一個(gè) socket 連接 wx.connectSocket({ url: ’ws://localhost:3000’, data: {x: ’’,y: ’’ }, header: {’content-type’: ’application/json’ }, method: ’GET’, success: function (res) {console.log(’connect success: ’, res) }, fail: function (err) {console.log(’connect error: ’, err) } }) // 監(jiān)聽(tīng)websocket打開(kāi)事件 wx.onSocketOpen(function (res) { console.log(’WebSocket連接已經(jīng)打開(kāi)!’) socketOpen = true for (var i = 0, len = socketMsgQueue.length; i < len; i++) {sendSocketMessage(socketMsgQueue[i]) } // 關(guān)閉socket wx.closeSocket() // socketMsgQueue = [] }) function sendSocketMessage(msg) { if (socketOpen) {wx.sendSocketMessage({data: msg}) } else {socketMsgQueue.push(msg) } } // 監(jiān)聽(tīng)WebSocket錯(cuò)誤 wx .onSocketError(function (res) {console.log(’WebSocket連接打開(kāi)失敗, 請(qǐng)檢查!’) }) // wx.sendSocketMessage 通過(guò)WebSocket連接發(fā)送數(shù)據(jù), 需要先先 wx.connectSocket, 并在 // wx.onSocketOpen 回調(diào)之后才能發(fā)送 監(jiān)聽(tīng)WebSocket 接收到拂去其的消息事件 wx.onSocketMessage(function (res) { console.log(’收到服務(wù)器內(nèi)容: ’ + res.data) }) // 關(guān)閉WebSocket連接 監(jiān)聽(tīng)websocket連接 wx.onSocketClose(function (res) { console.log(’WebSocket 已關(guān)閉!’) })BUG
WebSocket connection to ’ws://localhost:3000/’ failed: Connection closed before receiving a handshake response
為什么在握手前就斷開(kāi)連接了?
已知的問(wèn)題是:
微信小程序必須要 wss協(xié)議
在客戶端如果用 socket.io方式就可以,換成 html5的websocket 或 微信小程序內(nèi)置的socket方式 都不行(socket.io使用的是http協(xié)議)。
想知道的是:
微信小程序可以設(shè)置 socket以 http 協(xié)議請(qǐng)求嗎?或者有什么有得解決方法?
問(wèn)題解答
回答1:微信小程序 websocket 協(xié)議版本為13 你可以抓包看下而 socket.io 支持的協(xié)議版本為4 socket.io-protocol
ws支持協(xié)議版本13 可以用ws包或者以他為依賴的中間件ws
相關(guān)文章:
1. java - mongodb分片集群下,count和聚合統(tǒng)計(jì)問(wèn)題2. javascript - vue 移動(dòng)端的input 數(shù)字輸入優(yōu)化3. java - 自己制作一個(gè)視頻播放器,遇到問(wèn)題,用的是內(nèi)置surfaceview類,具體看代碼!4. javascript - 有什么兼容性比較好的辦法來(lái)判斷瀏覽器窗口的類型?5. 服務(wù)器端 - 采用nginx做web服務(wù)器,C++開(kāi)發(fā)應(yīng)用程序 出現(xiàn)拒絕連接請(qǐng)求?6. 為什么我ping不通我的docker容器呢???7. python - pandas按照列A和列B分組,將列C求平均數(shù),怎樣才能生成一個(gè)列A,B,C的dataframe8. 關(guān)于docker下的nginx壓力測(cè)試9. javascript - npm start 運(yùn)行’webpack-dev-server’報(bào)錯(cuò) Cannot find module ’webpack’10. java 隨機(jī)延遲執(zhí)行
