http/https与websocket的ws/wss的关系
今天在域名升級到HTTPS的時候遇到websocket的鏈接問題,之前在http下使用的是new WebSocket('ws://xxx');但是在切換到HTTPS后這個鏈接部分瀏覽器報錯甚至代碼整體拋出異常走不下去了,之前沒有注意過websocket在兩個不同協議下有什么不同,實際上按照標準來是有如下對應關系的
http ->?new WebSocket('ws://xxx')
https ->?new WebSocket('wss://xxx')
?也就是在https下應該使用wss協議做安全鏈接,且wss下不支持ip地址的寫法,寫成域名形式
經過測試,部分報錯的瀏覽器的確是因為這個原因導致的代碼異常,即在https下把ws換成wss請求即可,看到這里心細的也許會發現,是部分瀏覽器,實際上瀏覽器并沒有嚴格的限制http下一定使用ws,而不能使用wss,經過測試http協議下同樣可以使用wss協議鏈接,https下同樣也能使用ws鏈接,那么出問題的是哪一部分呢
1.Firefox環境下https不能使用ws連接
2.chrome內核版本號低于50的瀏覽器是不允許https下使用ws鏈接
3.Firefox環境下https下使用wss鏈接需要安裝證書
?實際上主要是問題出在Firefox以及低版本的Chrome內核瀏覽器上,于是在http與https兩種協議都支持的情況下可以做兼容處理,即在http協議下使用ws,在https協議下使用wss
let protocol = location.protocol === 'https:' ? 'wss://localhost:8888' : 'ws://localhost:8889'; new WebSocket(protocol);這樣可以更加不同的協議環境采取不同的鏈接方法,當然如果只支持https那最好還是使用wss協議,避免Firefox以及部分低版本Chrome內核瀏覽器的異常,當然新版本的瀏覽器都是支持的
總結
以上是生活随笔為你收集整理的http/https与websocket的ws/wss的关系的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【电子学会】2020年06月图形化四级
- 下一篇: 小米净水器与小区过滤价格水对照.xls