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內核瀏覽器的異常,當然新版本的瀏覽器都是支持的

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章