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. javascript - sublime快鍵鍵問題2. javascript - immutable配合react提升性能?3. css - 寫頁面遇到個布局問題,求大佬們幫解答,在線等,急!~4. 實現bing搜索工具urlAPI提交5. vue.js - Vue 如何像Angular.js watch 一樣監聽數據變化6. javascript - nodejs關于進程間發送句柄的一點疑問7. 配置Apache時,添加對PHP的支持時語法錯誤8. phpstudy8.1支持win11系統嗎?9. javascript - vue-router 地址改變數據未改變10. javascript - 移動端上不能實現拖拽布局嗎?

網公網安備