node.js - 微信小程序 +nodejs+socket.io bug
問題描述
技術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’, ’恭喜您, 您已經連接上了我們的聊天室了, 現在您可以開始聊天了’) 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) { // 頁面初始化 options為頁面跳轉所帶來的參數 // 創建一個 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) } }) // 監聽websocket打開事件 wx.onSocketOpen(function (res) { console.log(’WebSocket連接已經打開!’) socketOpen = true for (var i = 0, len = socketMsgQueue.length; i < len; i++) {sendSocketMessage(socketMsgQueue[i]) } // 關閉socket wx.closeSocket() // socketMsgQueue = [] }) function sendSocketMessage(msg) { if (socketOpen) {wx.sendSocketMessage({data: msg}) } else {socketMsgQueue.push(msg) } } // 監聽WebSocket錯誤 wx .onSocketError(function (res) {console.log(’WebSocket連接打開失敗, 請檢查!’) }) // wx.sendSocketMessage 通過WebSocket連接發送數據, 需要先先 wx.connectSocket, 并在 // wx.onSocketOpen 回調之后才能發送 監聽WebSocket 接收到拂去其的消息事件 wx.onSocketMessage(function (res) { console.log(’收到服務器內容: ’ + res.data) }) // 關閉WebSocket連接 監聽websocket連接 wx.onSocketClose(function (res) { console.log(’WebSocket 已關閉!’) })BUG
WebSocket connection to ’ws://localhost:3000/’ failed: Connection closed before receiving a handshake response
為什么在握手前就斷開連接了?
已知的問題是:
微信小程序必須要 wss協議
在客戶端如果用 socket.io方式就可以,換成 html5的websocket 或 微信小程序內置的socket方式 都不行(socket.io使用的是http協議)。
想知道的是:
微信小程序可以設置 socket以 http 協議請求嗎?或者有什么有得解決方法?
問題解答
回答1:微信小程序 websocket 協議版本為13 你可以抓包看下而 socket.io 支持的協議版本為4 socket.io-protocol
ws支持協議版本13 可以用ws包或者以他為依賴的中間件ws
相關文章:
1. mysql - 這條聯合sql語句哪里錯了2. webpack - vuejs+java前后臺分離實現及部署問題3. docker start -a dockername 老是卡住,什么情況?4. docker容器呢SSH為什么連不通呢?5. docker鏡像push報錯6. docker網絡端口映射,沒有方便點的操作方法么?7. Docker for Mac 創建的dnsmasq容器連不上/不工作的問題8. docker安裝后出現Cannot connect to the Docker daemon.9. javascript - vue 前端渲染項目SEO10. javascript - JS繼承,如何避免父類原型的object類型屬性會受子類影響的情況;
