這篇文章給大家分享的是有關(guān)workerman出現(xiàn)403錯誤怎么辦的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
創(chuàng)新互聯(lián)是一家專業(yè)提供巴宜企業(yè)網(wǎng)站建設(shè),專注與做網(wǎng)站、成都網(wǎng)站設(shè)計、H5場景定制、小程序制作等業(yè)務(wù)。10年已為巴宜眾多企業(yè)、政府機構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)絡(luò)公司優(yōu)惠進行中。
workerman出現(xiàn)錯誤如下:
400 Bad Request
Sec-WebSocket-Key not found.
This is a WebSocket service and can not be accessed via HTTP.
錯誤原因
出現(xiàn)這個錯誤說明你用http協(xié)議去訪問了websocket協(xié)議的服務(wù)。推薦:workerman教程
開發(fā)者要注意,客戶端使用的應(yīng)用層協(xié)議要與服務(wù)端的應(yīng)用層協(xié)議相同,也就是服務(wù)端是什么協(xié)議,客戶端就使用什么協(xié)議。
如果協(xié)議不對應(yīng)就會出現(xiàn)類似這種拒絕通訊甚至出錯的情況。
這個道理就像在瀏覽器地址欄里訪問數(shù)據(jù)庫的ip:3306端口一樣,你不會指望數(shù)據(jù)庫真的會給你返回什么有用的信息吧?
正確做法
正確的做法應(yīng)該是建立一個websocket協(xié)議的鏈接,利用websocket協(xié)議與workerman的websocket協(xié)議服務(wù)通訊。 如果客戶端是瀏覽器,可以利用js建立websocket鏈接,代碼類似這樣:
// 假設(shè)服務(wù)端ip為127.0.0.1,端口為2346 ws = new WebSocket("ws://127.0.0.1:2346"); ws.onopen = function() { alert("連接成功"); ws.send('tom'); alert("給服務(wù)端發(fā)送一個字符串:tom"); }; ws.onmessage = function(e) { alert("收到服務(wù)端的消息:" + e.data); };
感謝各位的閱讀!關(guān)于“workerman出現(xiàn)403錯誤怎么辦”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!