欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

WebSocket部署服務(wù)器但外網(wǎng)無法連接的解決方法

 更新時(shí)間:2017年10月17日 10:53:08   作者:微笑刺客D  
WebSocket是html5新增加的一種通信協(xié)議,目前流行的瀏覽器都支持這個(gè)協(xié)議,例如Chrome,Safari,Firefox,Opera,IE等等,下面這篇文章主要給大家介紹了關(guān)于WebSocket部署服務(wù)器但外網(wǎng)無法連接的解決方法,需要的朋友可以參考下。

前言

本文主要給大家介紹了關(guān)于WebSocket部署服務(wù)器外網(wǎng)無法連接的相關(guān)內(nèi)容,分享出來供大家參考學(xué)習(xí),下面話不多說了,來一起看看詳細(xì)的介紹吧。

首先要說的是我遇見的問題:

WebSocket connection to 'ws://www.xxxx.com/xxx/xx' failed: Error during WebSocket handshake: Unexpected response code: 200

網(wǎng)站綁定到了服務(wù)器,直接在服務(wù)器上訪問webSocket服務(wù)是可行的,但是當(dāng)我用外網(wǎng)訪問時(shí),這個(gè)錯(cuò)誤就是我最大的敵人,在這之前還遇到過幾個(gè)小毛賊,可以輕松解決,不再提,直面boss吧

花費(fèi)兩個(gè)下午的時(shí)間尋找解決方案,但是并沒有找到,各種解決方案,但是直接來描述.NET下使用這一問題的,卻是不多,然而面對了這一問題的朋友,大把的有。

這個(gè)無關(guān)瀏覽器問題,我有火狐,谷歌,IE測試過,該出的問題還是會(huì)有。

開發(fā)平臺(tái):.NET,利用ASP.NET MVC搭建網(wǎng)站,在其中利用WebSocket服務(wù),目的是在網(wǎng)站內(nèi)設(shè)計(jì)一個(gè)討論平臺(tái)。

具體來說一說:

首先,看下我的網(wǎng)頁代碼:

<script type="text/javascript">
  $(function () {
   var url = "ws://xxxx:xx"+"@Url.Action("RequestProcessCenter")";
   var ws;
   function connect() {
    ws = new WebSocket(url);
    $("#TopicContent").append("正在連接\n");
    ws.onopen = function () {
     $("#TopicContent").append("已經(jīng)連接\n");
    };
    ws.onmessage = function (evt) {
     console.log(evt.data);
     $("#TopicContent").append(evt.data);
    };
    ws.onclose = function () {
     $("#TopicContent").append("已經(jīng)關(guān)閉\n");
    };
    ws.onerror = function (evt) {
     console.log(evt.data);
     $("#TopicContent").append(evt.data);
    };
   };
   $("#send").click(function () {
    console.log(1);
    console.log(ws.readyState);
    console.log(WebSocket.OPEN);
    if (ws.readyState == WebSocket.OPEN) {
     ws.send($("#content").val());
     $(this).val("");
    }
    else {
     $("#TextMessge").append("連接已經(jīng)關(guān)閉");
    }
   });
   $("#open").click(function () {
    connect();
   });
   $("#close").click(function () {
    ws.close();
   });
  });
 </script>

后臺(tái)代碼:

public void RequestProcessCenter()
  {
   if (HttpContext.IsWebSocketRequest)
   {
    var currUser = GetCurrUser();
    this._UserName = currUser.LoginName;
    HttpContext.AcceptWebSocketRequest(ProcessTopic);
   }
   else
   {
    HttpContext.Response.Write("請求失敗喲");
   }
  }

webSocket所要求的url格式我想應(yīng)該是不會(huì)配錯(cuò)。

錯(cuò)誤顯示如圖:

返回200,盡管是請求成功了,但是結(jié)果不是我們想要的。

請求方式也確實(shí)是websocket,錯(cuò)誤卻存在了,這是為什么呢?查詢了很多資料,但是并沒有發(fā)現(xiàn)真正解決這一問題的,或許是我找的方式有問題,但是百度前三頁我是看了,并沒有想要的解決方案。自己動(dòng)手,做了個(gè)測試,反而發(fā)現(xiàn)有效。

我在服務(wù)器上部署的網(wǎng)站,用的是默認(rèn)的80端口,訪問會(huì)失效,如果webSocket不用和網(wǎng)站綁定的同一端口呢?

經(jīng)過該測試:

      1.本地80端口綁定域名 webSocket利用域名,端口80 無效

      2.本地80端口綁定域名 webSocket利用2017端口 主機(jī)地址用服務(wù)器ip地址 有效

      3.本地2017端口 未綁定域名 webSocket利用80端口 無效

      4.本地2017端口 未綁定域名 webSocket利用2017端口 有效

總結(jié) 80端口可能受系統(tǒng)限制

另一方面:域名綁定是否會(huì)影響 沒有測試

成功解決了外網(wǎng)雖返回200卻不能使用websocket服務(wù)的問題。

這種情況下需要注意的是,IIS服務(wù)器上需要添加兩個(gè)網(wǎng)站了,一個(gè)用于正常的80端口網(wǎng)頁訪問,另一個(gè)做單獨(dú)的WebSocket功能,這兩個(gè)網(wǎng)站可以使用同一個(gè)程序版本,我就是這么做的,沒有什么好的想法,菜鳥級人物。

https://www.infoq.com/articles/Web-Sockets-Proxy-Servers

這個(gè)網(wǎng)站介紹了WebSocket的一些知識,以及websocket默認(rèn)使用80-433端口,或許我在想,是不是我網(wǎng)站綁定的端口和websocket綁定相同端口時(shí),外網(wǎng)請求就是此時(shí)出的錯(cuò)呢,這個(gè)問題也一時(shí)半會(huì)不能深究,暫時(shí)性的功能是達(dá)到了,但是感覺這個(gè)解決方案不是很好的,只能是說滿足了需求,卻不能簡化需求過程。

留下一個(gè)猜想,我在服務(wù)器上訪問時(shí),是可行的,都是使用80端口,websocket服務(wù)能夠正常使用,那是因?yàn)樵诜?wù)器上發(fā)起時(shí),直接訪問的就是我本地服務(wù),所以說防火墻不會(huì)阻止,但是我使用外網(wǎng)訪問時(shí),入網(wǎng)規(guī)則或許阻擋了我的請求,點(diǎn)擊連接,發(fā)起調(diào)用WebSocket服務(wù),而服務(wù)端口也使用80端口,引起防火墻識別出問題。

或許猜想是很不合理的,但是在沒有找到具體問題下,我還是只有依靠分析問題出現(xiàn)原因,來解決我的問題。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • git?stash(儲(chǔ)藏)的用法總結(jié)

    git?stash(儲(chǔ)藏)的用法總結(jié)

    本文詳細(xì)講解了git?stash(儲(chǔ)藏)的用法,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • 解決git 提交后中文字符會(huì)亂碼的問題

    解決git 提交后中文字符會(huì)亂碼的問題

    這篇文章主要介紹了解決git 提交后中文字符會(huì)亂碼的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • postman測試接口各種類型傳值的實(shí)現(xiàn)

    postman測試接口各種類型傳值的實(shí)現(xiàn)

    本文主要介紹了postman測試接口各種類型傳值的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • Git如何修改已提交的commit注釋

    Git如何修改已提交的commit注釋

    這篇文章主要介紹了Git如何修改已提交的commit注釋問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • vscode 一鍵規(guī)范代碼格式的實(shí)現(xiàn)

    vscode 一鍵規(guī)范代碼格式的實(shí)現(xiàn)

    這篇文章主要介紹了vscode 一鍵規(guī)范代碼格式的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • 通過自定義字段重新排序 WordPress 文章方法

    通過自定義字段重新排序 WordPress 文章方法

    在本文中,我將向您展示如何通過自定義字段更改文章的順序。WordPress 中文章的默認(rèn)順序基于發(fā)布日期,并按時(shí)間倒序顯示。這意味著它將在頂部顯示最新的文章。
    2021-09-09
  • Vscode 打字特效插件Power Mode安裝使用介紹

    Vscode 打字特效插件Power Mode安裝使用介紹

    本文給大家推薦的是一款Vscode的打字特效的插件Power Mode的安裝使用說明,插件非常的炫酷,推薦給大家,希望大家能夠喜歡
    2020-02-02
  • php asp.net 比較 [推薦]

    php asp.net 比較 [推薦]

    如今當(dāng)提到 Web 開發(fā)時(shí),您有許多選擇。這些方法中許多都涉及到預(yù)處理 - 即,利用特定的標(biāo)記將代碼嵌入到 HTML 頁面中
    2009-06-06
  • git clone下來的代碼如何放在指定路徑

    git clone下來的代碼如何放在指定路徑

    這篇文章主要介紹了git clone下來的代碼如何放在指定路徑,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • 算法系列15天速成 第七天 線性表【上】

    算法系列15天速成 第七天 線性表【上】

    人活在社會(huì)上不可能孤立,比如跟美女有著千絲萬縷的關(guān)系,有的是一對一,有的是一對多,有的是多對多
    2013-11-11

最新評論