记录使用websocket时因为Sec-Websocket-Protocol遇到的一个问题
生活随笔
收集整理的這篇文章主要介紹了
记录使用websocket时因为Sec-Websocket-Protocol遇到的一个问题
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
前言
最近在做的項目中用到了websocket,在谷歌瀏覽器中顯示正常,別人在百度瀏覽器打開,沒有數據顯示,百度瀏覽器是ie內核,開始時先想到的是websocket的兼容性,結果證實websokcet是支持ie的。
百度瀏覽器的報錯
WebSocket connection to 'wss://://pusher.rising.com/app/4a530ae5e37bb480c08b?protocol=7&client=js&version=2.2. 0&flash=false' fai failed: Error during WebSocket handshake: Sent non-empty 'Sec-WebSocket-Protocol' header but no response was received 復制代碼直譯過來是因為websocket握手時,發了一個不為空的頭,Sec-WebSocket-Protocol,但是沒有接受這個頭的響應。 所以將問題焦點聚集在了Sec-WebSocket-Protocol。
百度和谷歌瀏覽器請求投的差異
同一個請求谷歌瀏覽器的請求頭是沒有Sec-WebSocket-Protocol這個字段的,而百度瀏覽器是傳了一個undefined。原因大致明了,因為Sec-WebSocket-Protocol傳值造成的。
聲明websocket的方法
var Socket = new WebSocket(url, [protocol] ); 復制代碼以上代碼中的第一個參數 url, 指定連接的 URL。第二個參數 protocol 是可選的,指定了可接受的子協議,是可選的。當我們給proctocol傳遞一個為空的變量時,谷歌瀏覽器會自動過濾掉值為空的請求頭,兒百度瀏覽器會將undefind傳遞過去。
解決方法
很簡單,穿第二個參數的時候加一層判斷,如果為空,就只傳一個參數就可以了。
轉載于:https://juejin.im/post/5be2b51d51882516df0306ba
總結
以上是生活随笔為你收集整理的记录使用websocket时因为Sec-Websocket-Protocol遇到的一个问题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 使用git时ssh提示“Load key
- 下一篇: virtualbox 安装虚拟机(cen