{
  "version": "https://jsonfeed.org/version/1", 
  "title": "WebSocket", 
  "description": null, 
  "home_page_url": "https://www.v2ex.com/go/ws", 
  "feed_url": "https://www.v2ex.com/feed/ws.json", 
  "items": [
    {
      "author": {
        "url": "https://www.v2ex.com/member/puremaker", 
        "name": "puremaker", 
        "avatar": "https://cdn.v2ex.com/avatar/cc2d/7de5/647810_large.png?m=1754989837"
      }, 
      "url": "https://www.v2ex.com/t/1138403", 
      "title": "\u5982\u679c\u6709\u591a\u4e2a websocket \u4e1a\u52a1\u9700\u6c42\uff0c\u4e00\u822c\u60c5\u51b5\u4e0b\u540e\u7aef\u662f\u5efa\u7acb\u4e00\u4e2a\u8fd8\u662f\u591a\u4e2a websocket \u66f4\u597d\uff1f", 
      "id": "https://www.v2ex.com/t/1138403", 
      "date_published": "2025-06-13T07:00:01+00:00", 
      "content_html": "<p>\u5c31\u6bd4\u5982\u8bf4\uff0c\u626b\u7801\u767b\u5f55\u7528\u5230\u4e86 websocket \uff0c\u9762\u677f\u76d1\u63a7\u7528\u5230\u4e86 websocket \uff0c\u8fd8\u6709\u5176\u4ed6\u4e1c\u897f\u4e5f\u7528\u5230\u4e86 websocket \u3002\n\u6211\u5c31\u662f\u5728\u8003\u8651\u5206\u522b\u7ed9\u4e0d\u540c\u4e1a\u52a1\u53bb\u5efa\u7acb\u670d\u52a1\u597d\uff0c\u8fd8\u662f\u8bf4\u5c3d\u91cf\u5c11\u7684\u53bb\u5efa\u7acb\u670d\u52a1\uff0c\u7136\u540e\u7528\u4f20\u53c2\u53bb\u5206\u8fa8\u4e1a\u52a1\u5e76\u5904\u7406\u597d\u3002\n\u63a5\u89e6 websocket \u4e0d\u4e45\uff0c\u6c42\u89e3\u60d1</p>\n"
    }, 
    {
      "author": {
        "url": "https://www.v2ex.com/member/dinghaichao27", 
        "name": "dinghaichao27", 
        "avatar": "https://cdn.v2ex.com/avatar/a4b6/83bf/549719_large.png?m=1773043183"
      }, 
      "url": "https://www.v2ex.com/t/1120634", 
      "date_modified": "2025-03-26T10:10:18+00:00", 
      "content_html": "\u5728\u9879\u76ee\u8fd0\u884c\u8fc7\u7a0b\u4e2d \u5728\u6d4b\u8bd5\u7f13\u89e3 webSocket \u65f6\u4e0d\u65f6\u91cd\u8fde \u5c5e\u4e8e\u6b63\u5e38\u73b0\u8c61\u5417\uff1f\u540e\u7aef\u7ed9\u51fa\u7684\u56de\u7b54\u8bf4\u662f\u6b63\u5e38 \u6b63\u5e38\u5417\uff1f", 
      "date_published": "2025-03-24T04:02:24+00:00", 
      "title": "webSocket \u5728\u9879\u76ee\u8fd0\u52a8\u8fc7\u7a0b\u4e2d \u53ef\u4ee5\u65f6\u4e0d\u65f6\u91cd\u65b0\u8fde\u63a5\u5417\uff1f", 
      "id": "https://www.v2ex.com/t/1120634"
    }, 
    {
      "author": {
        "url": "https://www.v2ex.com/member/chen0520", 
        "name": "chen0520", 
        "avatar": "https://cdn.v2ex.com/gravatar/74604c3787ac4138d717040a1ba5d64a?s=73&d=retro"
      }, 
      "url": "https://www.v2ex.com/t/1066528", 
      "date_modified": "2024-08-20T10:50:48+00:00", 
      "content_html": "<p>\u6211\u4e4b\u524d\u4e00\u76f4\u4ee5\u4e3a\u662f\u6570\u636e\u4f20\u8f93\u5b8c\u4e86\uff0c\u672c\u5730\u7ec4\u88c5\uff0c\u7136\u540e\u6d4f\u89c8\u5668\u4ece\u4e00\u4e2a\u672c\u5730\u7684\u5730\u5740\u4e0b\u8f7d\uff0c\u7136\u800c\u5b9e\u9645\u4e0a\u6d4b\u8bd5\u7ed3\u679c\u597d\u50cf\u6709\u70b9\u4e0d\u592a\u5bf9\uff0c\u6570\u636e\u4f20\u8f93\u5b8c\u4e86\u4e4b\u540e\uff0c\u8fd8\u662f\u9700\u8981\u8d70\u4e00\u4e2a\u4ece\u670d\u52a1\u5668\u7684\u4e0b\u8f7d(\u6d4f\u89c8\u5668\u4e0a\u7684\u533a\u522b\u662f\u6ca1\u6709\u8fdb\u5ea6\u6761)\uff0c\u7136\u540e\u6b64\u65f6\u5173\u95ed\u670d\u52a1\uff0c\u8fd9\u4e2a\u65f6\u5019\u4e0b\u8f7d\u4f1a\u7acb\u523b\u5931\u8d25\uff0c\u66f4\u6709\u610f\u601d\u7684\u4e8b\uff0c\u5982\u679c\u7ecf\u8fc7 nginx \u7684\u4ee3\u7406\uff0c\u5373\u4f7f\u5173\u6389\u4e86\u539f\u670d\u52a1\uff0c\u6b64\u65f6\u7684\u4e0b\u8f7d\u8fd8\u5728\u8fdb\u884c\uff0c\u6240\u4ee5\u6211\u6709\u70b9\u8d39\u89e3\u4e86\uff0c\u7b49\u4e8e\u6211\u4e00\u4e2a\u6587\u4ef6\u6570\u636e\u4ece\u670d\u52a1\u5668\u62c9\u4e86 2 \u904d\uff1f\u90a3\u6211\u8d70 websocket \u4e0b\u8f7d\u7684\u610f\u4e49\u662f\u4ec0\u4e48\u5462\uff1f</p>\n", 
      "date_published": "2024-08-20T10:45:31+00:00", 
      "title": "websocket \u4e0b\u8f7d\u6587\u4ef6\u7684\u539f\u7406\u662f\u5565\uff1f", 
      "id": "https://www.v2ex.com/t/1066528"
    }, 
    {
      "author": {
        "url": "https://www.v2ex.com/member/v2li32", 
        "name": "v2li32", 
        "avatar": "https://cdn.v2ex.com/gravatar/389d1eec17ba2ea9418e658ca985a0be?s=73&d=retro"
      }, 
      "url": "https://www.v2ex.com/t/1040165", 
      "date_modified": "2024-05-14T01:09:25+00:00", 
      "content_html": "<p>\u6211\u5728\u6784\u601d\u5fae\u670d\u52a1\u4e0b\u5982\u4f55\u901a\u8fc7 websocket \u4f5c\u4e3a\u4ea4\u4e92\u3002</p>\n<h1>\u8fd0\u884c\u6d41\u7a0b</h1>\n<p>client =&gt; http =&gt; server  =&gt; ws/tcp  =&gt;   server2 \u6536\u5230\t =&gt;  server2 \u901a\u8fc7 unixsocket \u6295\u9012\u6d88\u606f\u5230 work \u5904\u7406\u5b8c\u6210\u540e =&gt;\t\u901a\u8fc7 ws \u5199\u6d88\u606f\u56de\u53bb  =&gt; server \u7684 ws \u6536\u5230\u6d88\u606f </p>\n<p>\u8fd9\u4e2a\u65f6\u5019 \u5982\u679c\u6b63\u5e38\u5904\u7406  \u52a0\u5de5\u6536\u5230\u7684\u6d88\u606f\uff0c \u5199\u5165\u6d88\u606f\u5230 client \u7684 fd,close \u6389 client \u8fde\u63a5 \u5e94\u8be5\u662f\u53ef\u884c\u7684\u3002</p>\n<h2>\u5e73\u5e38\u4e1a\u52a1\u4ee3\u7801</h2>\n<p>client =&gt; server(\u4f2a\u4ee3\u7801\uff09=&gt; return </p>\n<pre><code class=\"language-php\">&lt;?php\n\nfunc add(){\n\t$get= $_REQUEST_PARAMS;\n\treturn success(\"code=&gt;200,data=$get,msg=''\");\n}\n\n</code></pre>\n<h2>\u5982\u679c\u6362\u6210\u4e0a\u9762\u901a\u8fc7 websocket \u4ea4\u4e92</h2>\n<p>\u90fd\u4e0d\u9700\u8981\u8fd4\u56de\u4e86, server \u6536\u5230 server2 \u7ed3\u679c\u540e fwrite($client_fd,$data);  close($client_fd);</p>\n<pre><code class=\"language-php\">&lt;?php\n\nfunc add(){\n\t$get= $_REQUEST_PARAMS;\n    (new Ws)-&gt;send($get);\n}\n\n</code></pre>\n<p>\u4e0a\u9762\u5199\u597d\u5947\u602a\u7684\u6837\u5b50\u3002\u3002   \u6211\u60f3\u5b9e\u73b0\u4e0b\u9762\u7684\u5199\u6cd5\u6709\u529e\u6cd5\u5417(\u4ee3\u7801\u76f4\u89c2\u770b\u7740\u8212\u670d)\uff0c\u6bd4\u5982</p>\n<pre><code class=\"language-php\">&lt;?php\n\nfunc add(){\n\t$get= $_REQUEST_PARAMS;\n    $res = (new Ws)-&gt;send($get);\n\n    return success(\"code=&gt;200,data=$res,msg=''\");\n}\n</code></pre>\n<p>\u5982\u679c\u60f3\u5b9e\u73b0\u4e0a\u9762\u8fd9\u6837\u5b50\uff0c\u9700\u8981\u5728\u52a0\u4e00\u4e2a\u961f\u5217(\u8d77\u5230 while true \u963b\u585e\u6548\u679c\uff1f)\u3002</p>\n<p>\u5f00\u8f9f 1 \u7247\u5185\u5b58 $arr[$client_fd] =&gt; $data; \u6570\u636e\u56de\u6765\u540e\u5199\u5165\u3002\u7136\u540e pop \u6d88\u606f\u3002  </p>\n<p>\u8fd9\u6837\u5b50\u5c31\u597d\u50cf\u6210 select \u4e86\u3002\u3002 \u65e0\u65f6\u65e0\u523b\u5728\u904d\u5386\uff0c\u6709\u6570\u636e\u5728\u8fd4\u56de\uff0c\u6027\u80fd\u95ee\u9898\u5f88\u5927\u3002\u3002  </p>\n<p>\u7136\u540e\u597d\u50cf\u4e3a\u4e86\u89e3\u51b3\u95ee\u9898\u53c8\u5f15\u5165\u65b0\u7684\u95ee\u9898\u3002 </p>\n<p>\u5927\u4f6c\u4eec\u7ed9\u70b9\u601d\u8def\u5462</p>\n", 
      "date_published": "2024-05-13T02:34:22+00:00", 
      "title": "websocket \u5982\u4f55\u6295\u9012\u6d88\u606f\u5230 http", 
      "id": "https://www.v2ex.com/t/1040165"
    }, 
    {
      "author": {
        "url": "https://www.v2ex.com/member/zzzmh", 
        "name": "zzzmh", 
        "avatar": "https://cdn.v2ex.com/avatar/36a9/2909/403095_large.png?m=1656297668"
      }, 
      "url": "https://www.v2ex.com/t/1033162", 
      "date_modified": "2024-04-17T03:45:44+00:00", 
      "content_html": "<p>\u4e00\u4e2a\u8981\u6c42\u9ad8\u5e76\u53d1\u9ad8\u540c\u6b65\u7684\u62cd\u5356\u9879\u76ee\n\u5f53\u521d\u7528\u7684\u662f jdk17 springboot3 springboot-websocket \u5b9e\u73b0\n\u6253\u5305\u6210 war \u653e\u5728 docker \u4e0b\u7684 tomcat10 \u8fd0\u884c\n\u670d\u52a1\u5668\u914d\u7f6e\u662f\n2C8G10M\n\u76ee\u524d\u7684\u95ee\u9898\u662f\n\u6211\u7528\u5176\u4ed6\u7a0b\u5e8f\u6a21\u62df socket \u5ba2\u6237\u7aef\u8fde\u63a5\uff0c\u5199\u4e86\u4e2a\u7a0b\u5e8f\u6d4b\u5e76\u53d1\n\u53d1\u73b0\u4eba\u6570\u5230\u8fbe 500+\u5e76\u540c\u65f6\u95f4\u9694\u51e0\u79d2\u7ed9\u670d\u52a1\u5668\u53d1\u6d88\u606f\u6536\u6d88\u606f\u7684\u65f6\u5019\n\u51fa\u73b0\u4e86\u660e\u663e\u7684\u963b\u585e\uff0c\u5176\u4e2d\u90e8\u5206\u8d26\u53f7\u53ef\u4ee5\u6b63\u5e38\u53d1\u51fa\u6d88\u606f\uff0c\u4f46\u662f\u670d\u52a1\u5668\u7684\u6d88\u606f\u5df2\u7ecf\u6536\u4e0d\u5230\u4e86\n\u670d\u52a1\u5668\u7aef\u7684\u76d1\u63a7\u663e\u793a\u6b64\u65f6 CPU RAM \u5916\u7f51\u5e26\u5bbd \u5747\u8fd8\u6709\u5145\u8db3\u4f59\u91cf</p>\n<p>\u6240\u4ee5\u6211\u60f3\u95ee\u95ee\u4e0b\u4e00\u6b65\u4f18\u5316\u6027\u80fd\u7684\u601d\u8def\uff0c\n\u7528\u4ec0\u4e48\u8f6f\u4ef6\u6a21\u62df\u5ba2\u6237\u7aef\u6d4b\u8bd5\u5408\u7406\n\u670d\u52a1\u7aef\u6ca1\u6709\u660e\u663e\u7684\u63a7\u5236\u53f0\u62a5\u9519\u7684\u524d\u63d0\u4e0b\uff0c\u8fd8\u6709\u4ec0\u4e48\u8c03\u67e5\u6027\u80fd\u7684\u65b9\u6cd5\u548c\u601d\u8def\n\u4e0b\u4e00\u6b65\u6211\u5e94\u8be5\u5982\u4f55\u8fdb\u884c\uff0c\u9664\u4e86\u91cd\u65b0\u5f00\u53d1\u4ee5\u5916</p>\n<p>\u7b2c\u4e00\u6b21\u63a5\u89e6 websocket \u88ab\u8d76\u9e2d\u5b50\u4e0a\u67b6\uff0c\u95ee\u7684\u95ee\u9898\u4e0d\u4e13\u4e1a\u52ff\u602a\u3002</p>\n", 
      "date_published": "2024-04-17T02:15:09+00:00", 
      "title": "\u9ebb\u70e6\u95ee\u4e2a Java websocket \u7684\u6027\u80fd\u4f18\u5316\u95ee\u9898(\u6bd4\u8f83\u57fa\u7840)", 
      "id": "https://www.v2ex.com/t/1033162"
    }, 
    {
      "author": {
        "url": "https://www.v2ex.com/member/laaaaaa", 
        "name": "laaaaaa", 
        "avatar": "https://cdn.v2ex.com/gravatar/7ab53dcc7f4f10f9a6c8b1a76a2ba638?s=73&d=retro"
      }, 
      "url": "https://www.v2ex.com/t/1029168", 
      "date_modified": "2024-04-03T00:58:58+00:00", 
      "content_html": "<h2>\u73af\u5883</h2>\n<pre><code>springboot + websocket + vue\n</code></pre>\n<h2>\u573a\u666f</h2>\n<pre><code>\u56fe\u6587\u5f62\u5f0f\u7684\u804a\u5929\uff0c\u6709\u5f00\u542f\u4f1a\u8bdd\u548c\u7ed3\u675f\u4f1a\u8bdd\uff0c\u6bcf\u6b21\u7ed3\u675f\u4e4b\u540e\uff0c\u628a\u672c\u6b21\u4f1a\u8bdd\u7684\u804a\u5929\u8bb0\u5f55\u5b58\u8d77\u6765\uff08\u56e0\u4e3a\u8981\u63a8\u7ed9\u7b2c\u4e09\u65b9\uff09\uff1b\n\n\u76ee\u524d\u662f\u7eaf\u539f\u751f\u7684 websocket \u5b9e\u73b0\uff1b\n</code></pre>\n<h2>\u9700\u6c42</h2>\n<pre><code>1.\u56fe\u7247\u7684\u4f20\u8f93\u65b9\u5f0f\uff0c\u4e86\u89e3\u4e24\u79cd\u65b9\u5f0f a.base64 \uff0cb.\u5ba2\u6237\u7aef\u9009\u62e9\u5b8c\u56fe\u7247\u4e4b\u540e\uff0c\u5148\u4e0a\u4f20\u5230 OSS, \u7136\u540e\u62ff\u5230\u8fd4\u56de\u7684\u5730\u5740\u6e32\u67d3 \uff1b \u4fdd\u5b58\u4f1a\u8bdd\u8bb0\u5f55\u7684\u65f6\u5019\uff0c\u6d88\u606f\u91cc\u5b58\u56fe\u7247\u7684\u5730\u5740\uff1b \u6709\u6ca1\u6709\u66f4\u597d\u7684\u65b9\u5f0f\u63a8\u8350\uff1b\n\n2.\u8fd9\u79cd\u5b58\u50a8\u804a\u5929\u8bb0\u5f55\uff0c\u5982\u679c\u4f7f\u7528 mysql \u6765\u5b58\u7684\u8bdd\uff0c\u8868\u5982\u4f55\u4f18\u96c5\u8bbe\u8ba1\uff1b \u6216\u8005\u6362\u79cd\u65b9\u5f0f\u5b58\u50a8\uff0c\u6587\u672c\u6216\u8005 es \uff1b\n\n3.\u7814\u7a76\u4e86\u4e00\u4e0b socket.io \uff0c\u4f7f\u7528 socket.io \u91cd\u6784\u7684\u8bdd \u63d0\u5347\u5927\u5417\uff1f\n</code></pre>\n", 
      "date_published": "2024-04-02T08:00:23+00:00", 
      "title": "\u8bf7\u6559\u4e00\u4e0b websocket \u5b9e\u73b0\u53d1\u56fe\u7247\u7684\u65b9\u6848\u548c\u4fdd\u5b58\u804a\u5929\u8bb0\u5f55\u7684\u65b9\u6848\uff1b", 
      "id": "https://www.v2ex.com/t/1029168"
    }, 
    {
      "author": {
        "url": "https://www.v2ex.com/member/victimsss", 
        "name": "victimsss", 
        "avatar": "https://cdn.v2ex.com/gravatar/c0e2a5a20f7f42283e9654867c485cbe?s=73&d=retro"
      }, 
      "url": "https://www.v2ex.com/t/992391", 
      "date_modified": "2023-11-16T05:30:23+00:00", 
      "content_html": "\u76ee\u524d\u4f7f\u7528 ws \u6216\u8005 node-websocket \u7684\u5e93\u3002\u5047\u5982\u4f5c\u4e3a\u4e00\u4e2a websocket client \uff0c\u4e1a\u52a1\u9700\u6c42\u672c\u8eab\u662f\u5b9a\u65f6\u63a8\u9001\u6d88\u606f\u7684\uff0c\u662f\u4e0d\u662f\u6ca1\u5fc5\u8981\u7ef4\u62a4\u5fc3\u8df3\uff08\u53ca\u65f6\u91cd\u8fde\uff09\u4e86\uff0c\u56e0\u4e3a\u6211\u89c9\u5f97\u5fc3\u8df3\u66f4\u591a\u662f\u4fdd\u6301\u6d3b\u8dc3\u9632\u6b62\u5173\u95ed\u8fde\u63a5\u7684\uff0c\u800c close \u4e8b\u4ef6\u5df2\u7ecf\u627f\u62c5\u4e86\u68c0\u6d4b\u8fde\u63a5\u72b6\u6001\u7684\u529f\u80fd\u3002 \u5047\u5982\u53ea\u662f\u76d1\u542c close \u4e8b\u4ef6\u6765\u7ef4\u62a4\u91cd\u8fde\uff0c\u4f1a\u6709\u4ec0\u4e48\u6bd4\u8f83\u5927\u9690\u60a3\u5417\uff0c\u6bd4\u5982\u8fde\u63a5\u5df2\u7ecf\u5173\u95ed\u4e86\u4f46\u662f close \u4e8b\u4ef6\u4e0d\u89e6\u53d1\uff08\uff1f\uff09", 
      "date_published": "2023-11-16T03:15:12+00:00", 
      "title": "\u95ee\u4e9b websocket \u7684\u95ee\u9898", 
      "id": "https://www.v2ex.com/t/992391"
    }, 
    {
      "author": {
        "url": "https://www.v2ex.com/member/dyllen", 
        "name": "dyllen", 
        "avatar": "https://cdn.v2ex.com/gravatar/ef035fc38a99e5b989a403705558b976?s=73&d=retro"
      }, 
      "url": "https://www.v2ex.com/t/989205", 
      "date_modified": "2023-11-06T13:39:44+00:00", 
      "content_html": "<p>websocket \u91cc\u9762 ping/pong \u673a\u5236\u6807\u51c6\u89c4\u5b9a\u5c31\u662f\u670d\u52a1\u7aef\u53d1 ping \uff0c\u5ba2\u6237\u7aef\u54cd\u5e94 pong \u5417\uff1f</p>\n", 
      "date_published": "2023-11-06T09:20:13+00:00", 
      "title": "websocket \u7684 ping/pong \u6807\u51c6\u662f\u9700\u8981\u670d\u52a1\u5668\u4e3b\u52a8\u53d1 ping\uff1f", 
      "id": "https://www.v2ex.com/t/989205"
    }, 
    {
      "author": {
        "url": "https://www.v2ex.com/member/rcj6056", 
        "name": "rcj6056", 
        "avatar": "https://cdn.v2ex.com/gravatar/0309611f6c86b1a4fc2b7c7f2e970d5a?s=73&d=retro"
      }, 
      "url": "https://www.v2ex.com/t/985692", 
      "date_modified": "2023-10-28T00:45:42+00:00", 
      "content_html": "<p>\u76ee\u524d\u901a\u8fc7 httpclien.webSocketClient \u6765\u5b9e\u73b0 websocket \u7684\u5efa\u94fe\n\u901a\u8fc7 DefaultClientWebSocketSession \u6765\u63a5\u53d7\u670d\u52a1\u7aef\u63a8\u9001\u7684\u6d88\u606f session.incoming.receive()</p>\n<p>\u76ee\u524d\u95ee\u9898\u662f\n\u5f53 app \u9000\u51fa\u5230\u540e\u53f0 \u9501\u5c4f\u4e00\u6bb5\u65f6\u95f4\u4e4b\u540e app \u88ab\u51bb\u7ed3\u4e86 \u518d\u6b21\u6253\u5f00 app \u5c31\u4f1a\u51fa\u73b0\nException: java.net.SocketTimeoutException: timeout\nException: kotlinx.coroutines.channels.ClosedReceiveChannelException: Channel was closed\n\u7c7b\u4f3c\u7684\u5f02\u5e38 </p>\n<p>\u60f3\u8bf7\u95ee\u8fd9\u79cd\u60c5\u51b5\u600e\u4e48\u5904\u7406</p>\n<p>ps \u63d0\u4f9b\u601d\u8def\u5e76\u89e3\u51b3\u7684\u8001\u54e5\u6709\u7ea2\u5305\u611f\u8c22:D</p>\n", 
      "date_published": "2023-10-26T08:17:12+00:00", 
      "title": "[\u6709\u507f] \u539f\u751f app \u5f00\u53d1\u5373\u65f6\u901a\u8baf \u5173\u4e8e websocket \u957f\u94fe\u63a5\u7684\u95ee\u9898", 
      "id": "https://www.v2ex.com/t/985692"
    }, 
    {
      "author": {
        "url": "https://www.v2ex.com/member/qazwsxkevin", 
        "name": "qazwsxkevin", 
        "avatar": "https://cdn.v2ex.com/gravatar/bfefb99d6203d351791672a1d3fc936a?s=73&d=retro"
      }, 
      "url": "https://www.v2ex.com/t/984626", 
      "date_modified": "2023-10-23T11:30:38+00:00", 
      "content_html": "<pre><code>import datetime\nimport random\nimport string\nimport asyncio\nimport time\n\nimport websockets\n\nfrom multiprocessing import Manager\nfrom concurrent import futures\n\n# \u5ffd\u7565\u8b66\u544a\nimport warnings\nwarnings.filterwarnings(\"ignore\")\n\nstrLen = 30\n\ndef putmsg(que, gvar):\n    cc = 0\n    while True:\n        cc += 1\n\n        if gvar['flag'] == True:\n            break\n\n        ranStr = ''\n        for s in range(strLen):\n            ranStr = ranStr + random.choice(string.ascii_letters + string.digits)\n\n        # slTime = random.uniform(0.01,0.2)\n\n        logStr = str(cc) + ' ' + \"{:.2f}\".format(slTime) + ' ' + str(datetime.datetime.now().replace(microsecond=0)) + ' ' + ranStr\n        # print(logStr)\n\t\t\n        # test\n        # print(cc, '#', que.qsize())\n\n        que.put(logStr)\n\n        # time.sleep(slTime)\n        time.sleep(1.5)\n\ndef wsock(queu, gvar):\n    loop = asyncio.get_event_loop()\n    async def stoploop():\n        loop.stop()\n\n    # Maintain a list of connected clients\n    connected_clients = set()\n\n    async def register(websocket):\n        # Add a new client to the list\n        connected_clients.add(websocket)\n        print('connected_clients.add(websocket)')\n\n    async def unregister(websocket):\n        # Remove a client from the list\n        connected_clients.remove(websocket)\n        print('connected_clients.remove(websocket)')\n\n    async def broadcast(message):\n        # Send a message to all connected clients\n        if connected_clients:\n            await asyncio.gather(*(client.send(message) for client in connected_clients))\n\n    async def echo(websocket, que=queu):\n        await register(websocket)\n\n        while True:\n            if queu.qsize():\n                msgStr = queu.get()\n                if connected_clients:\n                    try:\n                        await asyncio.gather(*(client.send(msgStr) for client in connected_clients))\n                    except Exception as e:\n                        print(e) # echo:received 1001 (going away); then sent 1001 (going away)\n                        break\n            else:\n                asyncio.sleep(0.3)\n\n\n        async for message in websocket:\n            # Broadcast the received message to all clients\n            if message == 'stop':\n                gvar['flag'] = True\n                await stoploop()\n            await broadcast(message)\n\n        await unregister(websocket)\n\n\n    start_server = websockets.serve(echo, \"172.17.0.2\", 25299)\n\n    asyncio.set_event_loop(loop)\n    # loop.create_task(start_server)\n    asyncio.get_event_loop().run_until_complete(start_server)\n    asyncio.get_event_loop().run_forever()\n\nif __name__ == '__main__':\n    # \u961f\u5217\n    msgQue = Manager().Queue()\n    # \u5168\u5c40\u53d8\u91cf\n    glovar = Manager().dict()\n\n    # \u542f\u505c\u5f00\u5173\n    glovar['flag'] = False\n\n    # \u5904\u7406\u8fdb\u7a0b\n    proc = futures.ProcessPoolExecutor(max_workers=2)\n\n    wsockRet = proc.submit(wsock, msgQue, glovar)\n    putmsgRet = proc.submit(putmsg, msgQue, glovar)\n</code></pre>\n<p>\u95ee\u9898\u662f websocket.serve \u4f7f\u7528 echo \u65b9\u6cd5\u4f5c\u4e3a handle \uff0c<br/>\n\u53ea\u6709\u5728 websocket \u63a5\u53e3\u6709\u4e8b\u4ef6\u7684\u65f6\u5019\uff0c\u624d\u4f1a\u8c03\u7528 echo \u8fdb\u884c\u5904\u7406\uff0c\uff08\u88ab\u52a8\u5f0f\uff09                  </p>\n<p>echo \u7684\u88ab\u52a8\u65b9\u6cd5\uff0c\u961f\u5217\u91cc\u7684\u65e5\u5fd7\u8d8a\u6765\u8d8a\u591a\uff0c<br/>\n\u60f3\u6709\u4e00\u4e2a\u6c38\u4e45\u5faa\u73af\uff0c\u5982\u679c\u6709 client(s)\uff0csend \u53d6\u51fa\u7684\u961f\u5217\u5185\u5bb9\uff0c\u6ca1\u6709 client \uff0c\u53d6\u51fa\u5c31 pass \u4e86\uff0c<br/>\nwebsocket.serve \u88ab\u52a8\u8c03\u7528\u4e0d\u9002\u5408\u8fd9\u4e2a\u573a\u5408\uff0c\u770b\u5b98\u65b9\u4e5f\u6ca1\u6709\u66f4\u597d\u7684\u63d0\u793a\uff0c<br/>\n\u8bf7\u6559\u5927\u5bb6\u8fd9\u91cc\u600e\u4e48\u6362\u4e2a\u65b9\u5f0f\u5b9e\u73b0\u5462\uff1f</p>\n", 
      "date_published": "2023-10-23T10:50:13+00:00", 
      "title": "\u8bf7\u6559\uff0c websockets \u6a21\u5757\u8d77\u670d\u52a1\uff0c websockets.serve \u7684\u65b9\u6cd5\u95ee\u9898\u3002", 
      "id": "https://www.v2ex.com/t/984626"
    }, 
    {
      "author": {
        "url": "https://www.v2ex.com/member/looveh", 
        "name": "looveh", 
        "avatar": "https://cdn.v2ex.com/avatar/27ca/bb7c/634424_large.png?m=1740468668"
      }, 
      "url": "https://www.v2ex.com/t/984391", 
      "date_modified": "2023-10-23T04:43:54+00:00", 
      "content_html": "<p>\u505a\u4e86\u4e2a WebSocket \u8fde\u63a5\uff0c\u5ba2\u6237\u7aef\u901a\u8fc7\u5b9a\u65f6\u53d1\u9001\u5fc3\u8df3\u3002\u4f46\u662f\u65f6\u95f4\u4e00\u957f\u53d1\u73b0\u8fd8\u662f\u4f1a\u81ea\u52a8\u65ad\u5f00\uff0c\u5fc3\u8df3\u65f6\u95f4\u662f 30s \u4e00\u6b21\uff0cng \u4e5f\u505a\u4e86\u5982\u4e0b\u914d\u7f6e\uff1a</p>\n<pre><code>proxy-read-timeout\uff1a'3600'\nproxy-send-timeout\uff1a'3600'\n</code></pre>\n<p>\u6709\u6ca1\u6709\u5927\u4f6c\u51fa\u73b0\u8fc7\u8fd9\u79cd\u60c5\u51b5\uff1f\n\u9519\u8bef\u5982\u4e0b\uff1a</p>\n<pre><code> java.io.EOFException: null\n\n \tat org.apache.tomcat.util.net.NioEndpoint$NioSocketWrapper.fillReadBuffer(NioEndpoint.java:1345)\n\n \tat org.apache.tomcat.util.net.NioEndpoint$NioSocketWrapper.read(NioEndpoint.java:1255)\n\n \tat org.apache.tomcat.websocket.server.WsFrameServer.onDataAvailable(WsFrameServer.java:75)\n\n \tat org.apache.tomcat.websocket.server.WsFrameServer.doOnDataAvailable(WsFrameServer.java:183)\n\n \tat org.apache.tomcat.websocket.server.WsFrameServer.notifyDataAvailable(WsFrameServer.java:162)\n\n \tat org.apache.tomcat.websocket.server.WsHttpUpgradeHandler.upgradeDispatch(WsHttpUpgradeHandler.java:156)\n\n \tat org.apache.coyote.http11.upgrade.UpgradeProcessorInternal.dispatch(UpgradeProcessorInternal.java:60)\n\n \tat org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:59)\n\n \tat org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:893)\n\n \tat org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1707)\n\n \tat org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)\n\n \tat java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)\n\n \tat java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)\n\n \tat org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)\n\n \tat java.base/java.lang.Thread.run(Thread.java:829)\n</code></pre>\n", 
      "date_published": "2023-10-23T01:55:27+00:00", 
      "title": "WebSocket \u9891\u7e41\u7206\u51fa\u5f02\u5e38", 
      "id": "https://www.v2ex.com/t/984391"
    }, 
    {
      "author": {
        "url": "https://www.v2ex.com/member/longmeier90", 
        "name": "longmeier90", 
        "avatar": "https://cdn.v2ex.com/gravatar/8dbc4123e8644a41d1409ad8dd0d0b35?s=73&d=retro"
      }, 
      "url": "https://www.v2ex.com/t/909020", 
      "title": "\u95ee\u4e00\u4e2a websockets \u7684\u95ee\u9898", 
      "id": "https://www.v2ex.com/t/909020", 
      "date_published": "2023-01-15T03:19:24+00:00", 
      "content_html": "<pre><code>\u6211\u7528 python \u5199\u4e86\u4e00\u4e2a websockets \u4f8b\u5b50\uff0c \u670d\u52a1\u7aef\u548c\u5ba2\u6237\u7aef\u5728\u4e00\u53f0\u670d\u52a1\u5668\u4e0a\u5c31\u53ef\u4ee5\u6b63\u5e38\u901a\u4fe1\uff0c\n\u653e\u5728\u4e0d\u540c\u7684\u670d\u52a1\u5668\u5c31\u4f1a\u63d0\u793a\nerror\uff1awebsockets.exceptions.InvalidMessage: did not receive a valid HTTP response \u3002\n\u662f\u4e0d\u662f\u7f51\u7edc\u7684\u95ee\u9898\uff0c\u4e0d\u8fc7\u6211\u670d\u52a1\u5668\u9632\u706b\u5899\u4e0a\u7684\u7aef\u53e3\u90fd\u6253\u5f00\u4e86\u3002\n\nsever.py \u670d\u52a1\u7aef\n\n\nimport asyncio\nimport websockets\n\n# \u68c0\u6d4b\u5ba2\u6237\u7aef\u6743\u9650\uff0c\u7528\u6237\u540d\u5bc6\u7801\u901a\u8fc7\u624d\u80fd\u9000\u51fa\u5faa\u73af\nasync def check_permit(websocket):\n    while True:\n        recv_str = await websocket.recv()\n        cred_dict = recv_str.split(\":\")\n        print(\"\u63a5\u53d7\",cred_dict)\n        if cred_dict[0] == \"admin\" and cred_dict[1] == \"123456\":\n            response_str = \"congratulation, you have connect with server\\r\\nnow, you can do something else\"\n            await websocket.send(response_str)\n            return True\n        else:\n            response_str = \"sorry, the username or password is wrong, please submit again\"\n            await websocket.send(response_str)\n\n# \u63a5\u6536\u5ba2\u6237\u7aef\u6d88\u606f\u5e76\u5904\u7406\uff0c\u8fd9\u91cc\u53ea\u662f\u7b80\u5355\u628a\u5ba2\u6237\u7aef\u53d1\u6765\u7684\u8fd4\u56de\u56de\u53bb\nasync def recv_msg(websocket):\n    while True:\n        recv_text = await websocket.recv()\n        print(\"\u6d88\u606f:\",str(recv_text))\n        response_text = f\"your submit context: {recv_text}\"\n        await websocket.send(response_text)\n\n# \u670d\u52a1\u5668\u7aef\u4e3b\u903b\u8f91\n# websocket \u548c path \u662f\u8be5\u51fd\u6570\u88ab\u56de\u8c03\u65f6\u81ea\u52a8\u4f20\u8fc7\u6765\u7684\uff0c\u4e0d\u9700\u8981\u81ea\u5df1\u4f20\nasync def main_logic(websocket, path):\n    await check_permit(websocket)\n\n    await recv_msg(websocket)\n\nstart_server = websockets.serve(main_logic, '0.0.0.0', 8765)\n\nasyncio.get_event_loop().run_until_complete(start_server)\nasyncio.get_event_loop().run_forever()\n\n\n\n#### client.py \u5ba2\u6237\u7aef\n\nimport asyncio\nimport websockets\n\n# \u5411\u670d\u52a1\u5668\u7aef\u8ba4\u8bc1\uff0c\u7528\u6237\u540d\u5bc6\u7801\u901a\u8fc7\u624d\u80fd\u9000\u51fa\u5faa\u73af\nasync def auth_system(websocket):\n    while True:\n        cred_text = input(\"please enter your username and password: \")\n        await websocket.send(cred_text)\n        response_str = await websocket.recv()\n        if \"congratulation\" in response_str:\n            return True\n\n# \u5411\u670d\u52a1\u5668\u7aef\u53d1\u9001\u8ba4\u8bc1\u540e\u7684\u6d88\u606f\nasync def send_msg(websocket):\n    while True:\n        _text = input(\"please enter your context: \")\n        if _text == \"exit\":\n            print(f'you have enter \"exit\", goodbye')\n            await websocket.close(reason=\"user exit\")\n            return False\n        await websocket.send(_text)\n        recv_text = await websocket.recv()\n        print(f\"{recv_text}\")\n\n# \u5ba2\u6237\u7aef\u4e3b\u903b\u8f91\nasync def main_logic():\n    async with websockets.connect('ws://(server \u516c\u7f51 ip):8765') as websocket:\n        await auth_system(websocket)\n\n        await send_msg(websocket)\n\nasyncio.get_event_loop().run_until_complete(main_logic())\n\n\n</code></pre>\n"
    }, 
    {
      "author": {
        "url": "https://www.v2ex.com/member/dadagogogo", 
        "name": "dadagogogo", 
        "avatar": "https://cdn.v2ex.com/avatar/f3e1/21bb/541093_large.png?m=1634456280"
      }, 
      "url": "https://www.v2ex.com/t/806186", 
      "title": "Java \u4e2d websocket \u4e2d session \u957f\u4e45\u4fdd\u6301\u6253\u5f00\u72b6\u6001", 
      "id": "https://www.v2ex.com/t/806186", 
      "date_published": "2021-10-07T02:39:55+00:00", 
      "content_html": "<p>\u9879\u76ee\u7528 websocket\uff0c\u6bd4\u8f83\u7b80\u964b\u4e3a\u5355\u673a\u5f0f\u6709\u72b6\u6001\u7684\uff0c\u4e00\u4e2a session \u5bf9\u5e94\u4e00\u4e2a\u5bf9\u8c61\u53bb\u5904\u7406\u4e1a\u52a1\uff0c\u5e76\u5b58\u5728\u4e00\u4e2a ConcurrentHashMap \u4e2d\u3002session \u5173\u95ed\u540e\u4f1a\u4ece Map \u4e2d\u6e05\u6389\u3002\n\u73b0\u5728\u51fa\u73b0\u95ee\u9898\uff1a\u6253\u65e5\u5fd7\u53d1\u73b0 Map \u4e2d\u6709\u5927\u91cf\u672a\u6e05\u9664\u7684\u6570\u636e\uff0c\u4e14 session \u4fdd\u6301\u6253\u5f00\u7684\u60c5\u51b5\uff08\u8fd9\u4e9b session \u90fd\u662f\u6253\u5f00\u4e86\u6709\u597d\u51e0\u5929\u4e86\uff09\uff0c\u773c\u770b\u5185\u5b58\u6ea2\u51fa\u3002</p>\n"
    }, 
    {
      "author": {
        "url": "https://www.v2ex.com/member/miniyao", 
        "name": "miniyao", 
        "avatar": "https://cdn.v2ex.com/avatar/986e/3747/237684_large.png?m=1515160726"
      }, 
      "url": "https://www.v2ex.com/t/753756", 
      "date_modified": "2021-02-17T14:56:59+00:00", 
      "content_html": "\u4f7f\u7528 gevent worker \u4f5c\u4e3a Websocket \u670d\u52a1\u7aef\uff0c\u4e3a\u4e86\u907f\u514d\u65ad\u7ebf\uff0c\u6d4f\u89c8\u5668\u4e0a\u7528 setInterval \u5b9a\u65f6\u91cd\u590d\u5efa\u7acb Websocket\uff0c\u7ed3\u679c\u5bfc\u81f4 gevent \u4e0d\u4f1a\u81ea\u52a8\u91ca\u653e\u4e4b\u524d\u5e9f\u5f03\u7684\u8fde\u63a5\uff0c\u5185\u5b58\u5feb\u8981\u6ea2\u51fa\u4e86\u3002<br /><br />\u5f00\u59cb\u4ee5\u4e3a\u5ba2\u6237\u7aef\u91cd\u590d\u53d1\u8d77 websocket \u8fde\u63a5\uff0c\u4f1a\u8986\u76d6\u5148\u524d\u7684\u8fde\u63a5\uff0c\u7ed3\u679c\u53d1\u73b0\u6ca1\u6709\u3002<br /><br />\u5ba2\u6237\u7aef\u53d1\u8d77\u65b0\u7684 websocket \u8fde\u63a5\uff0c\u670d\u52a1\u5668\u5e76\u6ca1\u6709\u7acb\u5373\u9500\u6bc1\u4e4b\u524d\u5e9f\u5f03\u7684\u8fde\u63a5\uff0c\u4e45\u800c\u4e45\u4e4b\uff0c\u5185\u5b58\u91cc\u5806\u780c\u4e86\u8d8a\u6765\u8d8a\u591a\u7684\u5e9f\u5f03\u8fde\u63a5\u3002<br /><br />\u95ee\u9898\uff1a<br />\u65e2\u5e0c\u671b\u907f\u514d\u5ba2\u6237\u7aef\u610f\u5916\u65ad\u7ebf\uff0c\u6ca1\u6cd5\u81ea\u52a8\u91cd\u65b0\u8fde\u63a5\uff1b<br />\u53c8\u5e0c\u671b\u4e0d\u8981\u628a\u670d\u52a1\u5668\u5185\u5b58\u9010\u6e10\u6324\u7206\u4e86\u3002<br />\u53d1\u8d77\u91cd\u65b0\u8fde\u63a5\u7684\u65f6\u5019\uff0c\u628a\u5ba2\u6237\u7aef\u5df2\u7ecf\u5173\u95ed\u7684 socket \u8fde\u63a5\u6e05\u9664\u4e86\u3002<br />\u600e\u4e48\u81ea\u52a8\u56de\u6536\u5e9f\u5f03\u8fde\u63a5\u5462\uff1f", 
      "date_published": "2021-02-17T14:55:17+00:00", 
      "title": "\u4f7f\u7528 gevent \u4f5c\u4e3a Websocket \u670d\u52a1\u7aef\uff0c\u6d4f\u89c8\u5668\u4e0a\u7528 setInterval \u5b9a\u65f6\u91cd\u590d\u5efa\u7acb Websocket\uff0c\u7ed3\u679c\u5bfc\u81f4 gevent \u4e0d\u4f1a\u81ea\u52a8\u91ca\u653e\u4e4b\u524d\u5e9f\u5f03\u7684\u8fde\u63a5\uff0c\u5185\u5b58\u5feb\u8981\u6ea2\u51fa\u4e86\u3002\u600e\u4e48\u81ea\u52a8\u56de\u6536\u5e9f\u5f03\u8fde\u63a5\u5462", 
      "id": "https://www.v2ex.com/t/753756"
    }, 
    {
      "author": {
        "url": "https://www.v2ex.com/member/HenryWang0723", 
        "name": "HenryWang0723", 
        "avatar": "https://cdn.v2ex.com/avatar/61ca/6ce1/348517_large.png?m=1536570259"
      }, 
      "url": "https://www.v2ex.com/t/723242", 
      "date_modified": "2020-11-09T07:45:07+00:00", 
      "content_html": "<p>\u9879\u76ee\u662f\u524d\u540e\u7aef\u5206\u79bb\uff0cSpringBoot+Vue\uff0c\u76ee\u524d\u7684\u63a5\u53e3\u90fd\u7528\u7684 SpringSecurity \u6846\u67b6\uff0c\u7981\u7528\u4e86 session \u6539\u4e3a\u4e86 jwt \u5355\u70b9\u767b\u5f55\uff0c\u73b0\u5728\u9879\u76ee\u8981\u52a0\u5165 websocket \u3002\u6211\u7406\u89e3\u7684 websocket \u53ea\u5728\u63e1\u624b\u7684\u65f6\u5019\u53d1 http\uff0c\u90a3\u4e48\u5728\u63e1\u624b\u65f6\u5728\u8bf7\u6c42\u7684 header \u91cc\u52a0 jwt token \uff08\u8c8c\u4f3c STOMP \u53ef\u4ee5\u505a\u5230\uff09\uff0c\u4f9d\u65e7\u7528 Security \u8fdb\u884c\u62e6\u622a\uff0c\u540e\u7eed websocket \u5efa\u7acb\u597d\u4e4b\u540e\u7684\u901a\u4fe1\u5c31\u81ea\u52a8\u653e\u8fc7\u4e86\uff1f\u8fd8\u662f\u8bf4\u6bcf\u4e00\u5305\u901a\u4fe1\u4f9d\u65e7\u662f http \u4f1a\u88ab Security \u5168\u90e8\u62e6\u622a..?</p>\n", 
      "date_published": "2020-11-09T07:43:48+00:00", 
      "title": "websocket \u5728 springsecurity \u4e0b\u7ed3\u5408 jwt \u7684\u95ee\u9898", 
      "id": "https://www.v2ex.com/t/723242"
    }, 
    {
      "author": {
        "url": "https://www.v2ex.com/member/GoEasyWebsocket", 
        "name": "GoEasyWebsocket", 
        "avatar": "https://cdn.v2ex.com/gravatar/e3ae9454d93d8461c3d76bf4e5b79b36?s=73&d=retro"
      }, 
      "url": "https://www.v2ex.com/t/716658", 
      "title": "sync-player\uff1a\u4f7f\u7528 websocket \u5b9e\u73b0\u5f02\u5730\u540c\u6b65\u64ad\u653e\u89c6\u9891", 
      "id": "https://www.v2ex.com/t/716658", 
      "date_published": "2020-10-20T03:55:06+00:00", 
      "content_html": "<blockquote>\n<p>\u672c\u6587\u4f5c\u8005\uff1a\u661f\u7a7a\u65e0\u9650</p>\n<p>\u539f\u6587\u94fe\u63a5\uff1a <a href=\"https://liyangzone.com/2020/09/20/%E5%89%8D%E7%AB%AF/sync-player/\" rel=\"nofollow\">https://liyangzone.com/2020/09/20/%E5%89%8D%E7%AB%AF/sync-player/</a></p>\n<p>GoEasy \u5df2\u83b7\u4f5c\u8005\u6388\u6743\u8f6c\u8f7d\uff0cGoEasy \u8f6c\u8f7d\u65f6\u6709\u6539\u52a8\uff0c\u611f\u8c22\u4f5c\u8005\u7684\u5206\u4eab\u3002</p>\n</blockquote>\n<p>\u524d\u6bb5\u65f6\u95f4\u6211\u6709\u8fd9\u6837\u4e00\u4e2a\u9700\u6c42\uff0c\u60f3\u548c\u4e00\u4e2a\u5f02\u5730\u7684\u4eba\u4e00\u8d77\u770b\u7535\u5f71\uff0c\u5148\u540e\u5728\u7f51\u4e0a\u627e\u4e86\u4e00\u4e9b\u65b9\u6848\uff0c\u4e0d\u8fc7\u90a3\u51e0\u4e2a\u6848\u90fd\u6709\u4e00\u4e9b\u7f3a\u70b9</p>\n<ul>\n<li>\n<p><strong>coplay:</strong> \u4e00\u4e2a\u6d4f\u89c8\u5668\u63d2\u4ef6\uff0c\u53ea\u80fd\u64ad\u653e\u5404\u5927\u89c6\u9891\u7f51\u7ad9\u7684\u89c6\u9891\uff0c\u89c6\u9891\u8d44\u6e90\u6709\u9650\uff0c\u6211\u60f3\u8981\u770b\u7684\u89c6\u9891\u6ca1\u6709\uff0c\u6bd4\u5982\u4e00\u4e9b\u7ecf\u5178\u7535\u5f71\u548c\u7f8e\u5267\u4e4b\u7c7b</p>\n</li>\n<li>\n<p><strong>\u5fae\u5149 APP:</strong> \u8fd8\u662f\u4e0a\u9762\u7684\u95ee\u9898\uff0c\u800c\u4e14\u53ea\u6709\u624b\u673a\u7aef</p>\n</li>\n<li>\n<p><strong>\u5411\u65e5\u8475\u7b49\u8fdc\u7a0b\u684c\u9762:</strong> \u53d7\u9650\u4e8e\u7f51\u7edc\u95ee\u9898\uff0c\u5361\u987f\u5f88\u4e25\u91cd\uff0c\u4f53\u9a8c\u4e0d\u597d</p>\n</li>\n</ul>\n<p>\u4f5c\u4e3a\u4e00\u4e2a\u5bf9\u7528\u6237\u4f53\u9a8c\u6709\u8ffd\u6c42\u7684\u5207\u56fe\u4ed4\uff0c\u6211\u662f\u4e00\u4e2a\u4e0b\u8f7d\u515a\uff0c\u770b\u7535\u5f71\u5fc5\u987b\u4e0b\u8f7d\u5230\u672c\u5730\u770b\uff0c\u57fa\u672c\u4e0d\u770b\u89c6\u9891\u7f51\u7ad9\u4e0a\u7684\u73a9\u610f</p>\n<p>\u90a3\u4e48\u6709\u6ca1\u6709\u80fd\u5b9e\u73b0\u540c\u6b65\u64ad\u653e\u672c\u5730\u6587\u4ef6\u7684\u65b9\u6848\u5462\uff0c\u7b54\u6848\u662f\u80af\u5b9a\u7684\uff0c\u7ecf\u8fc7\u6211\u7684\u4e00\u4e9b\u6478\u7d22\u548c\u7814\u7a76\uff0c\u6211\u5b9e\u73b0\u4e86\u672c\u5730\u6587\u4ef6\u7684\u540c\u6b65\u64ad\u653e\uff0c\u540c\u65f6\u652f\u6301 PC \u548c\u624b\u673a\u7aef\uff0c\u800c\u4e14\u8fd8\u652f\u6301\u5916\u6302\u5b57\u5e55\u7b49\u9ad8\u7ea7\u529f\u80fd\uff0c\u5982\u4f55\u5b9e\u73b0\u8bf7\u5f80\u4e0b\u770b\u3002</p>\n<h1>\u529f\u80fd\u4ecb\u7ecd&amp;\u7279\u6027\uff1a</h1>\n<p>\u4e00\u4e2a\u53ef\u4ee5\u540c\u6b65\u770b\u89c6\u9891\u7684\u64ad\u653e\u5668\uff0c\u53ef\u7528\u4e8e\u5f02\u5730\u540c\u6b65\u89c2\u5f71\u3001\u89c2\u5267\uff0c\u652f\u6301\u591a\u4eba\u540c\u65f6\u89c2\u770b\u3002\n\u672c\u9879\u76ee\u6709\u4e24\u4e2a\u7248\u672c\uff0cweb \u7248\u8fd0\u884c\u5728\u6d4f\u89c8\u5668\u4e0a\uff0c\u53ef\u8de8\u5e73\u53f0\uff0c\u4e0d\u9650\u64cd\u4f5c\u7cfb\u7edf\u3001\u8bbe\u5907\uff0c\u529f\u80fd\u7b80\u5355\u9002\u7528\u4e8e\u8981\u6c42\u4e0d\u9ad8\u7684\u7528\u6237\u3002\u8fd8\u6709\u57fa\u4e8e SPlayer(\u5c04\u624b\u5f71\u97f3)DIY \u7684\u5ba2\u6237\u7aef\u7248\u672c(windows \u3001MAC)\uff0c\u64ad\u653e 4K \u9ad8\u6e05\u6587\u4ef6\u3001\u5916\u6302\u5b57\u5e55\uff0c\u7edf\u7edf\u6ca1\u95ee\u9898\u3002</p>\n<h1>\u6f14\u793a demo:</h1>\n<p><strong>web \u7248\u540c\u6b65\u6548\u679c</strong>\n<img alt=\"BSQoHx.gif\" src=\"https://www.goeasy.io/articles/wp-content/uploads/2020/10/1.gif\"/>\n<strong>\u5ba2\u6237\u7aef\u4e0e web \u7248\u540c\u6b65\u6548\u679c</strong>\n<img alt=\"BSQID1.gif\" src=\"https://www.goeasy.io/articles/wp-content/uploads/2020/10/2.gif\"/></p>\n<h1>\u539f\u7406\uff1a</h1>\n<p>\u57fa\u4e8e websocket \u5b9e\u73b0\uff0c\u4e0e\u4e00\u4e9b\u7528 websocket \u5b9e\u73b0\u7684\u804a\u5929\u5ba4\u7c7b\u4f3c\uff0c\u53ea\u4e0d\u8fc7\u8fd9\u4e2a\u804a\u5929\u5ba4\u91cc\u7684\u6d88\u606f\u6362\u6210\u4e86\u64ad\u653e\u6682\u505c\u7684\u52a8\u4f5c\u548c\u65f6\u95f4\u4fe1\u606f\uff0c\u5ba2\u6237\u7aef\u6536\u5230\u6d88\u606f\u540e\u6267\u884c\u76f8\u5e94\u7684\u52a8\u4f5c:\u64ad\u653e\u3001\u6682\u505c\u3001\u5feb\u8fdb\uff0c\u4ee5\u8fbe\u5230\u540c\u65f6\u64ad\u653e\u7684\u6548\u679c\u3002</p>\n<h1>\u9879\u76ee\u6240\u7528\u5230\u7684</h1>\n<ul>\n<li>node.js</li>\n<li>socketio</li>\n<li>HTML5 video API</li>\n<li>vue.js</li>\n</ul>\n<h1>\u5982\u4f55\u4f7f\u7528\uff1a</h1>\n<p>\u672c\u9879\u76ee\u7684\u6838\u5fc3\u662f websocket\uff0c\u6240\u4ee5\u81f3\u5c11\u9700\u8981\u4e00\u53f0\u670d\u52a1\u5668\u63d0\u4f9b websocket \u670d\u52a1\uff0cwebsocket \u670d\u52a1\u53ef\u4ee5\u81ea\u5df1\u90e8\u7f72\uff0c\u53ef\u4ee5\u4f7f\u7528\u7b2c\u4e09\u65b9\u5e73\u53f0 GoEasy \u63d0\u4f9b\u7684 websocket \u670d\u52a1\u3002</p>\n<h2>1 \u3001\u81ea\u5df1\u90e8\u7f72\uff1a</h2>\n<p>websocket \u670d\u52a1\u5668\u53ef\u4ee5\u662f\u4e00\u53f0\u5177\u6709\u516c\u7f51 IP \u7684\u4e91\u670d\u52a1\u5668\uff0c\u4e5f\u53ef\u4ee5\u662f\u4e00\u53f0\u5177\u6709\u516c\u7f51 IP \u7684\u666e\u901a PC\uff0c\u6ca1\u6709\u516c\u7f51 IP \u4e5f\u53ef\u4ee5\u3002\u4f60\u4e5f\u53ef\u4ee5\u4f7f\u7528 zerotier \u6216\u5176\u4ed6 VPN \u5de5\u5177\u5c06\u4e24\u53f0\u8bbe\u5907\u7ec4\u6210\u4e00\u4e2a\u5927\u5c40\u57df\u7f51\uff0c\u8ba9\u5b83\u4eec\u80fd\u4e92\u76f8\u901a\u4fe1\u3002websocket \u670d\u52a1\u5668\u64cd\u4f5c\u7cfb\u7edf\u4e0d\u9650\uff0c\u53ea\u8981\u6709 node.js \u73af\u5883\u3002</p>\n<p>websocket \u670d\u52a1\u7aef\u90e8\u7f72\u65b9\u6cd5\uff1a\u5b89\u88c5 node.js \u73af\u5883\uff0c\u5c06 server \u76ee\u5f55\u79fb\u52a8\u5230\u670d\u52a1\u5668\u4e0a\uff0c\u8fdb\u5165 server \u76ee\u5f55\uff0c\u6267\u884c\u4ee5\u4e0b\u547d\u4ee4\uff1a</p>\n<p><strong>\u5b89\u88c5\u9879\u76ee\u4f9d\u8d56\u5305</strong></p>\n<pre><code># \u5b89\u88c5\u9879\u76ee\u4f9d\u8d56\u5305\n\nnpm install \n\n# \u542f\u52a8 websocket \u670d\u52a1\n\nnode index.js\n</code></pre>\n<h2>2 \u3001\u4f7f\u7528 GoEasy \u7684 websocket \u670d\u52a1</h2>\n<p>\u6ce8\u518c GoEasy \u5f00\u53d1\u8005\u8d26\u53f7\u5e76\u521b\u5efa\u4e00\u4e2a\u5e94\u7528\uff0c\u83b7\u5f97 appkey\uff0c\u590d\u5236\u5230\u672c\u9879\u76ee\u76f8\u5e94\u4f4d\u7f6e\u5373\u53ef\u3002</p>\n<p>GoEasy \u5b98\u7f51\uff1a<a href=\"https://www.goeasy.io\" rel=\"nofollow\">https://www.goeasy.io</a></p>\n<p>\u65e0\u8bba\u662f\u4f7f\u7528\u54ea\u79cd websocket \u670d\u52a1\u90fd\u53ef\u4ee5\uff0c\u672c\u9879\u76ee\u5199\u4e86\u4e24\u5957\u4ee3\u7801\uff0c\u53ea\u9700\u5c06\u4e0d\u7528\u7684\u90a3\u5957\u6ce8\u91ca\u6389\u5373\u53ef(\u9ed8\u8ba4 GoEasy)\u3002</p>\n<p>\u9664\u4e86 websocket \u670d\u52a1\u5668\u4e4b\u5916\uff0c\u8fd8\u9700\u8981\u4e24\u4e2a http \u670d\u52a1\u7aef\uff0c\u4e00\u4e2a\u662f web \u670d\u52a1\u7aef(\u63d0\u4f9b html \u3001css \u3001js \u7b49\u6587\u4ef6\u7684\u8bbf\u95ee)\uff0c\u4e00\u4e2a\u662f\u89c6\u9891\u670d\u52a1\u7aef(\u63d0\u4f9b\u89c6\u9891\u6587\u4ef6\u8bbf\u95ee)\u3002</p>\n<p><strong>\u4f60\u53ef\u4ee5\u5c06 web \u670d\u52a1\u90e8\u7aef\u7f72\u5230\u4ee5\u4e0b\u4f4d\u7f6e\uff1a</strong></p>\n<ul>\n<li>\u5177\u6709\u516c\u7f51 IP \u7684\u670d\u52a1\u5668</li>\n<li>github-pages \u6216\u56fd\u5185\u7684\u7801\u4e91\u63d0\u4f9b\u7684\u9759\u6001 web \u670d\u52a1</li>\n<li>localhost(\u672c\u5730\u670d\u52a1\u5668)\uff0c\u540c\u4e00\u4e2a\u5c40\u57df\u7f51\u5185\u7684\u8bbe\u5907\u8bbf\u95ee\u8be5\u670d\u52a1\u5668\u5185\u7f51 IP</li>\n</ul>\n<p><strong>\u89c6\u9891\u6587\u4ef6\u53ea\u9700\u4e00\u4e2a\u89c6\u9891\u5730\u5740\u5c31\u884c\uff0c\u4e5f\u6709\u4ee5\u4e0b\u51e0\u79cd\u9009\u62e9\uff1a</strong></p>\n<ul>\n<li>\u5177\u6709\u516c\u7f51 IP \u7684\u670d\u52a1\u5668</li>\n<li>localhost(\u672c\u5730\u670d\u52a1\u5668)\uff0c\u540c\u4e00\u4e2a\u5c40\u57df\u7f51\u5185\u7684\u8bbe\u5907\u8bbf\u95ee\u8be5\u670d\u52a1\u5668\u5185\u7f51 IP</li>\n<li>\u7b2c\u4e09\u65b9\u89c6\u9891\u5730\u5740</li>\n</ul>\n<p><img alt=\"image\" src=\"https://www.goeasy.io/articles/wp-content/uploads/2020/10/3.png\"/></p>\n<p><strong>\u4f7f\u7528\u573a\u666f 1\uff1a</strong></p>\n<p>\u4e91\u670d\u52a1\u5668\u5e26\u5bbd\u8db3\u591f\u5927(\u81f3\u5c11\u8981\u5927\u4e8e\u64ad\u653e\u89c6\u9891\u7684\u7801\u7387)\uff0c\u4e91\u670d\u52a1\u5668\u65e2\u53ef\u4ee5\u4f5c\u4e3a websocket \u670d\u52a1\u7aef\uff0c\u4e5f\u53ef\u4ee5\u4f5c\u4e3a http \u670d\u52a1\u7aef\u3002\u4e0a\u56fe\u4e2d\u6240\u6709\u8bbe\u5907\u90fd\u8bbf\u95ee\u4e91\u670d\u52a1\u5668\u7684 ip \u6216\u57df\u540d\u3002</p>\n<p><strong>\u4f7f\u7528\u573a\u666f 2\uff1a</strong></p>\n<p>\u4e91\u670d\u52a1\u5668\u7684\u5e26\u5bbd\u5f88\u5c0f\uff0c\u8fd9\u65f6\u5019\u5b83\u53ea\u80fd\u4f5c\u4e3a websocket \u670d\u52a1\u7aef\uff0c\u8fd9\u65f6\u53ef\u4ee5\u7528\u4e0a\u56fe\u4e2d\u7684 PC1 \u548c PC2 \u4f5c\u4e3a http \u670d\u52a1\u7aef\uff0cPC1 \u548c PHONE1 \u5728\u4e00\u4e2a\u5185\u7f51\u8bbf\u95ee PC1 \u7684\u5185\u7f51 IP\uff0cPC2 \u548c PHONE2 \u5728\u4e00\u4e2a\u5185\u7f51\u8bbf\u95ee PC2 \u7684\u5185\u7f51 IP\uff0cPC3 \u53ef\u4f5c\u4e3a\u81ea\u5df1\u7684 http \u670d\u52a1\u7aef\uff0cPHONE3 \u82e5\u662f\u6709\u63d0\u4f9b\u89c6\u9891\u6587\u4ef6\u7684\u670d\u52a1\u7aef\uff0c\u4e5f\u53ef\u4ee5\u4f7f\u7528\u3002\n<img alt=\"image\" src=\"https://www.goeasy.io/articles/wp-content/uploads/2020/10/4.png\"/>\n<strong>\u4f7f\u7528\u573a\u666f 3\uff1a</strong></p>\n<p>\u9700\u8981\u4f7f\u7528 zerotier \u6216\u5176\u4ed6 VPN \u5de5\u5177\u5c06\u5f02\u5730\u8bbe\u5907\u7ec4\u6210\u4e00\u4e2a\u5927\u5c40\u57df\u7f51\uff0c\u5176\u4e2d\u4efb\u610f\u4e00\u53f0 PC \u5747\u53ef\u4f5c\u4e3a websocket \u670d\u52a1\u7aef\u548c http \u670d\u52a1\u7aef(\u9700\u8981\u4e0a\u4f20\u5e26\u5bbd\u8db3\u591f\u5927)\u3002\u4e0a\u56fe\u4e2d\u5404\u8bbe\u5907\u90fd\u8bbf\u95ee\u90a3\u53f0 PC \u7684\u5185\u7f51 ip \u5373\u53ef\u3002</p>\n<p>\u6700\u7b80\u5355\u7684\u4f7f\u7528\u65b9\u6cd5\uff0c\u4e0b\u8f7d nginx \u5f00\u542f\u4e00\u4e2a\u672c\u5730\u670d\u52a1\u5668\uff0c\u4e0b\u8f7d\u672c\u9879\u76ee client \u6587\u4ef6\u5939\u653e\u5230\u5230 nginx \u6839\u76ee\u5f55\u91cc\uff0c\u89c6\u9891\u6587\u4ef6\u4e5f\u653e\u5230\u91cc\u9762\u3002\u6ce8\u518c goeasy \u5f00\u53d1\u8005\u8d26\u53f7\u5e76\u521b\u5efa\u4e00\u4e2a\u5e94\u7528\uff0c\u83b7\u5f97 appkey\uff0c\u5e76\u586b\u5165\u5230 appkey \u5230\u4ee3\u7801(script/main.js)\u76f8\u5e94\u4f4d\u7f6e\u3002\u7136\u540e\u6d4f\u89c8\u5668\u6253\u5f00 192.168.3.58/client/\uff0c\u586b\u5165\u4f60\u7684\u89c6\u9891\u5730\u5740 192.168.3.58/movie/xxx.mp4 \u6216\u7f51\u7edc\u89c6\u9891\u5730\u5740\uff0c\u5bf9\u65b9\u4e5f\u8fd9\u6837\u64cd\u4f5c\u4e00\u756a\uff0c\u5373\u53ef\u5b9e\u73b0\u540c\u6b65\u64ad\u653e\u89c6\u9891\u3002</p>\n<p>web \u7248\u672c\u7684\u529f\u80fd\u6bd4\u8f83\u7b80\u5355\uff0c\u800c\u4e14\u53d7\u9650\u4e8e\u7f51\u7edc\u95ee\u9898\uff0c\u5feb\u8fdb\u4e4b\u7c7b\u7684\u64cd\u4f5c\u9700\u8981\u7f13\u51b2\u4e00\u6bb5\u65f6\u95f4\u3002\u5982\u679c\u4f60\u4e0d\u6ee1\u8db3 web \u7248\u529f\u80fd\uff0c\u5bf9\u7528\u6237\u4f53\u9a8c\u6709\u66f4\u9ad8\u7684\u8981\u6c42\uff0c\u5982\u652f\u6301\u66f4\u591a\u6587\u4ef6\u683c\u5f0f\u3001\u64ad\u653e\u9ad8\u6e05\u672c\u5730\u89c6\u9891\u6587\u4ef6\u3001\u5916\u6302\u5b57\u5e55\u7b49\uff0c\u6211\u4e5f\u627e\u5230\u4e86\u53e6\u4e00\u79cd\u65b9\u5f0f\u6765\u6ee1\u8db3\u4f60\u7684\u9700\u6c42\u3002</p>\n<p>\u90a3\u5c31\u662f DIY \u4e00\u4e2a\u5f00\u6e90\u7684\u64ad\u653e\u5668\u7684\u6e90\u7801\uff1aSPlayer(\u5c04\u624b\u5f71\u97f3)\u3002</p>\n<p>\u5c04\u624b\u5f71\u97f3\u5b98\u7f51\uff1a <a href=\"https://splayer.org\" rel=\"nofollow\">https://splayer.org</a></p>\n<p>\u6e90\u7801\u5730\u5740\uff1a <a href=\"https://github.com/chiflix/splayerx\" rel=\"nofollow\">https://github.com/chiflix/splayerx</a></p>\n<p>\u5728\u4ee5 electron + \u64ad\u653e\u5668\u4e3a\u5173\u952e\u5b57\u4e00\u756a\u641c\u7d22\u4e4b\u540e\uff0c\u6211\u627e\u5230\u4e86\u8fd9\u4e2a\u57fa\u4e8e electron \u5b9e\u73b0\u7684\u5f00\u6e90\u64ad\u653e\u5668\uff0c\u5e76\u4e0b\u8f7d\u4e86\u6e90\u7801\u6765\u7814\u7a76\u3002</p>\n<p>\u7ecf\u8fc7\u4e00\u756a\u7814\u7a76\u4e4b\u540e\uff0c\u6211\u627e\u5230\u4e86\u63a7\u5236\u89c6\u9891\u64ad\u653e\u3001\u6682\u505c\u3001\u5feb\u8fdb\u7684\u4ee3\u7801\u4f4d\u7f6e\uff0c\u5e76\u5c06\u63a7\u5236\u540c\u6b65\u7684\u4ee3\u7801\u79fb\u690d\u4e86\u8fdb\u53bb\uff0c\u4ece\u800c\u4e5f\u5b9e\u73b0\u4e86\u540c\u6b65\u529f\u80fd\uff0c\u5e76\u4e14\u4e0e web \u7248\u517c\u5bb9\u3002</p>\n<p>\u5177\u4f53\u65b9\u6cd5\u8bf7\u770b\uff1a<a href=\"https://github.com/liyang5945/sync-player/blob/master/how-to-modify-splayer.md\" rel=\"nofollow\">\u4fee\u6539\u6559\u7a0b</a></p>\n<p>\u672c\u9879\u76ee\u90e8\u5206\u56fe\u6807\u6837\u5f0f\u6765\u6e90\u4e8e\u6b64\u9879\u76ee: <a href=\"https://github.com/Justineo/coplay\" rel=\"nofollow\">coplay</a></p>\n<p>\u672c\u9879\u76ee github \u5730\u5740\uff1a<a href=\"https://github.com/liyang5945/sync-player\" rel=\"nofollow\">\u70b9\u51fb\u524d\u5f80</a> \uff0c\u6b22\u8fce\u2b50\u2b50\u2b50STAR\u2b50\u2b50\u2b50</p>\n<h1>\u5173\u4e8e GoEasy\uff1a</h1>\n<p>GoEasy \u662f\u4e00\u4e2a\u6210\u719f\u7a33\u5b9a\u7684\u4f01\u4e1a\u7ea7 websocket PAAS \u670d\u52a1\u5e73\u53f0\uff0c\u5f00\u53d1\u4eba\u5458\u4e0d\u9700\u8981\u8003\u8651 websocket \u670d\u52a1\u7aef\u7684\u642d\u5efa\uff0c\u53ea\u9700\u8981\u51e0\u884c\u4ee3\u7801\uff0c\u5c31\u53ef\u4ee5\u8f7b\u677e\u5b9e\u73b0\u5ba2\u6237\u7aef\u4e0e\u5ba2\u6237\u7aef\u4e4b\u95f4\uff0c\u670d\u52a1\u5668\u4e0e\u5ba2\u6237\u7aef\u4e4b\u95f4\u7684\u7684 websocket \u901a\u4fe1\u3002</p>\n<p>GoEasy \u4f5c\u4e3a\u56fd\u5185\u9886\u5148\u7684\u7b2c\u4e09\u65b9 websocket \u6d88\u606f\u63a8\u9001\u5e73\u53f0\uff0c\u5177\u5907\u6781\u4f73\u7684\u517c\u5bb9\u6027\u3002\u9664\u4e86\u517c\u5bb9\u6240\u6709\u5e38\u89c1\u7684\u6d4f\u89c8\u5668\u4ee5\u5916\uff0c\u540c\u65f6\u4e5f\u517c\u5bb9 uni-app\uff0c\u5404\u79cd\u5c0f\u7a0b\u5e8f\uff0c\u4ee5\u53ca vue \u3001react-native \u3001cocos \u3001laya \u3001egret \u7b49\u5e38\u89c1\u7684\u524d\u7aef\u6846\u67b6\u3002</p>\n<p>\u540c\u65f6 GoEasy \u5df2\u7ecf\u5185\u7f6e websocket \u4e2d\u5fc5\u5907\u7684\u5fc3\u8df3\uff0c\u65ad\u7f51\u91cd\u8fde\uff0c\u6d88\u606f\u8865\u53d1\uff0c\u5386\u53f2\u6d88\u606f\u548c\u5ba2\u6237\u7aef\u4e0a\u4e0b\u7ebf\u63d0\u9192\u7b49\u7279\u6027\uff0c\u5f00\u53d1\u4eba\u5458\u4e5f\u4e0d\u9700\u8981\u81ea\u5df1\u642d\u5efa websocket \u670d\u52a1\u5904\u7406\u96c6\u7fa4\u9ad8\u53ef\u7528\uff0c\u5b89\u5168\u548c\u6027\u80fd\u95ee\u9898\u3002GoEasy \u5df2\u7ecf\u7a33\u5b9a\u8fd0\u884c\u4e86 5 \u5e74\uff0c\u652f\u6301\u5343\u4e07\u7ea7\u5e76\u53d1\uff0c\u6210\u529f\u652f\u6491\u8fc7\u5f88\u591a\u77e5\u540d\u4f01\u4e1a\u7684\u91cd\u8981\u6d3b\u52a8\uff0c\u5b89\u5168\u6027\u548c\u53ef\u9760\u6027\u90fd\u662f\u4e45\u7ecf\u8003\u9a8c\u3002</p>\n<p>\u6709\u5174\u8da3\u81ea\u5df1\u642d\u5efa websocket \u7684\u8bdd\uff0c\u53ef\u4ee5\u53c2\u8003\u8fd9\u7bc7\u6280\u672f\u5206\u4eab\u300a<a href=\"https://www.cnblogs.com/goeasy-websocket/p/12425696.html\" rel=\"nofollow\">\u642d\u5efa websocket \u6d88\u606f\u63a8\u9001\u670d\u52a1\uff0c\u5fc5\u987b\u8981\u8003\u8651\u7684\u51e0\u4e2a\u95ee\u9898</a>\u300b</p>\n"
    }, 
    {
      "author": {
        "url": "https://www.v2ex.com/member/jonychen1", 
        "name": "jonychen1", 
        "avatar": "https://cdn.v2ex.com/gravatar/e88d31c5f54b66367a32a1877e5d100e?s=73&d=retro"
      }, 
      "url": "https://www.v2ex.com/t/664579", 
      "title": "Websocket \u76f4\u64ad\u95f4\u804a\u5929\u5ba4\u6559\u7a0b - GoEasy \u5feb\u901f\u5b9e\u73b0\u804a\u5929\u5ba4", 
      "id": "https://www.v2ex.com/t/664579", 
      "date_published": "2020-04-21T04:02:15+00:00", 
      "content_html": "<p>\u6700\u8fd1\u4e24\u5e74\u76f4\u64ad\u90a3\u4e2a\u706b\u554a\uff0c\u771f\u7684\u662f\u65e0\u6cd5\u5f62\u5bb9\uff01\u7ecf\u5e38\u6709\u670b\u53cb\u95ee\u8d77\uff0c\u6211\u60f3\u5b9e\u73b0\u4e00\u4e2a\u76f4\u64ad\u95f4\u804a\u5929\u6216\u8005\u6211\u60f3\u5f00\u53d1\u4e00\u4e2a\u804a\u5929\u5ba4, \u8981\u5982\u4f55\u5f00\u59cb\u5462\uff1f</p>\n<p><img alt=\"image\" src=\"https://www.goeasy.io/articles/wp-content/uploads/2020/04/live-chatroom-1024x695.gif\"/></p>\n<p>\u4eca\u5929\u5c0f\u7f16\u5c31\u624b\u628a\u624b\u7684\u6559\u4f60\u7528 GoEasy \u505a\u4e00\u4e2a\u804a\u5929\u5ba4\uff0c\u5f53\u7136\u4e5f\u53ef\u4ee5\u7528\u4e8e\u76f4\u64ad\u95f4\u5185\u7684\u4e92\u52a8\u3002\u5168\u5957\u6e90\u7801\u5df2\u7ecf\u5f00\u6e90\uff0cgit \u5730\u5740\uff1a <a href=\"https://gitee.com/goeasy-io/GoEasyDemo-Live-Chatroom.git\" rel=\"nofollow\">https://gitee.com/goeasy-io/GoEasyDemo-Live-Chatroom.git</a></p>\n<p>\u672c\u6559\u7a0b\u4e3b\u8981\u76ee\u7684\u662f\u4e3a\u5927\u5bb6\u4ecb\u7ecd\u5b9e\u73b0\u601d\u8def\uff0c\u4e3a\u4e86\u786e\u4fdd\u672c\u6559\u7a0b\u80fd\u5e2e\u52a9\u5230\u4f7f\u7528\u4e0d\u540c\u524d\u7aef\u6280\u672f\u7684\u670b\u53cb\uff0c\u91c7\u7528\u4e86 HTML + JQuery \u7684\u65b9\u5f0f\uff0c\u540e\u7eed\u8fd8\u4f1a\u63a8\u51fa Uniapp(vue/nvue)\u548c\u5c0f\u7a0b\u5e8f\u7248\u672c\uff0c\u5927\u5bb6\u53ef\u4ee5\u6301\u7eed\u5173\u6ce8\u3002</p>\n<p>\u6211\u4eec\u8fd9\u6b21\u8981\u5b9e\u73b0\u7684\u804a\u5929\u5ba4\uff0c\u6709\u4e24\u4e2a\u754c\u9762\uff0c\u5206\u522b\u662f\uff1a</p>\n<ul>\n<li>\u767b\u5f55\u754c\u9762</li>\n<li>\u804a\u5929\u5ba4\u754c\u9762</li>\n</ul>\n<h1>\u767b\u5f55</h1>\n<p><img alt=\"image\" src=\"https://www.goeasy.io/articles/wp-content/uploads/2020/04/login.png\"/></p>\n<p><strong>\u5bf9\u4e8e\u767b\u5f55\u754c\u9762\uff0c\u6211\u4eec\u671f\u671b\uff1a</strong></p>\n<ul>\n<li>\u7528\u6237\u53ef\u4ee5\u8f93\u5165\u81ea\u5df1\u7684\u6635\u79f0</li>\n<li>\u7528\u6237\u53ef\u4ee5\u9009\u62e9\u81ea\u5df1\u559c\u6b22\u7684\u5934\u50cf</li>\n<li>\u7528\u6237\u53ef\u4ee5\u9009\u62e9\u8fdb\u5165\u4e0d\u540c\u7684\u804a\u5929\u5ba4\uff08\u76f4\u64ad\u95f4\uff09</li>\n</ul>\n<p><strong>\u5b9e\u73b0\u6b65\u9aa4</strong></p>\n<p>\u767b\u5f55\u754c\u9762\u7684\u5b9e\u73b0\uff0c\u4e0d\u7528\u591a\u8bf4\uff0c\u56e0\u4e3a\u771f\u7684\u662f So Easy! \u4e00\u4e2a\u7b80\u5355\u7684\u754c\u9762\uff0c\u53ea\u5305\u542b\u4e09\u4e2a\u7b80\u5355\u7684\u903b\u8f91\uff1a</p>\n<ul>\n<li>\u9a8c\u8bc1\u662f\u5426\u8f93\u5165\u6635\u79f0</li>\n<li>\u9a8c\u8bc1\u662f\u5426\u9009\u62e9\u4e00\u4e2a\u5934\u50cf</li>\n<li>\u6839\u636e\u9009\u62e9\u8fdb\u5165\u76f8\u5e94\u7684\u804a\u5929\u5ba4</li>\n</ul>\n<p>\u4e0b\u8fb9\u91cd\u70b9\u8bb2\u4e00\u4e0b\u804a\u5929\u5ba4\u7684\u5b9e\u73b0\u3002</p>\n<h1>\u804a\u5929\u5ba4\uff08\u76f4\u64ad\u95f4\uff09</h1>\n<p><img alt=\"image\" src=\"https://www.goeasy.io/articles/wp-content/uploads/2020/04/liveroom.png\"/></p>\n<p>\u5f53\u6211\u4eec\u8fdb\u5165\u4e00\u4e2a\u804a\u5929\u5ba4\u540e\uff0c\u6211\u4eec\u671f\u671b\uff1a</p>\n<ul>\n<li>\u7528\u6237\u80fd\u770b\u5230\u5f53\u524d\u6709\u591a\u5c11\u7528\u6237\u5728\u7ebf\uff0c\u8fd9\u4e2a\u6570\u5b57\u80fd\u591f\u5b9e\u65f6\u7684\u66f4\u65b0</li>\n<li>\u7528\u6237\u80fd\u770b\u5230\u5f53\u524d\u5728\u7ebf\u7528\u6237\u4eec\u7684\u5934\u50cf\uff0c\u800c\u4e14\u80fd\u591f\u5b9e\u65f6\u7684\u66f4\u65b0</li>\n<li>\u5982\u679c\u6709\u7528\u6237\u8fdb\u5165\u6216\u79bb\u5f00\u804a\u5929\u5ba4<br/>\na. \u804a\u5929\u5ba4\u4f1a\u6709\u201cXXX \u8fdb\u6765\u4e86\"\u6216\"XXX \u79bb\u5f00\u4e86\"\u7684\u63d0\u793a<br/>\nb. \u5728\u7ebf\u7528\u6237\u7684\u6570\u5b57\u548c\u7528\u6237\u7684\u5934\u50cf\u5217\u8868\u4f1a\u968f\u4e4b\u81ea\u52a8\u66f4\u65b0</li>\n<li>\u7528\u6237\u53ef\u4ee5\u5728\u804a\u5929\u91cc\u53d1\u8a00</li>\n<li>\u7528\u6237\u53ef\u4ee5\u53d1\u9001\u9053\u5177\uff1a\u706b\u7bad\u6216\u8005\u6bd4\u5fc3</li>\n</ul>\n<h3>\u5b9e\u73b0\u6b65\u9aa4</h3>\n<h4>\u7b2c\u4e00\u6b65\uff1a\u804a\u5929\u5ba4\u754c\u9762\u663e\u793a</h4>\n<p><strong>1. \u521d\u59cb\u5316\uff1a</strong></p>\n<p>\u5f53\u7528\u6237\u9009\u62e9\u4e86\u4e00\u4e2a\u804a\u5929\u5ba4\uff0c\u663e\u793a\u804a\u5929\u5ba4\u754c\u9762\u4e4b\u524d\uff0c\u6211\u4eec\u9996\u5148\u8981\u8fdb\u884c\u4ee5\u4e0b\u521d\u59cb\u5316\u5de5\u4f5c\uff1a</p>\n<ul>\n<li>\u521d\u59cb\u5316\u5f53\u524d\u7528\u6237 currentUser\uff0c\u7528\u6237 id\uff0c\u6635\u79f0\uff0c\u5934\u50cf</li>\n<li>\u521d\u59cb\u5316\u5f53\u524d\u804a\u5929\u5ba4 ID: currentRoomId</li>\n<li>\u521d\u59cb\u5316 GoEasy \u5bf9\u8c61\uff0c\u6ce8\u610f\u4e00\u5b9a\u8981\u52a0\u4e0a userId \u53c2\u6570\uff08\u53ef\u4ee5\u662f\u8be5\u7528\u6237\u7684 uuid \u6216 id \u7b49\u552f\u4e00\u6807\u8bc6\uff0c\u53ea\u6709\u8bbe\u7f6e\u4e86 userId \u7684\u5ba2\u6237\u7aef\u5728\u4e0a\u4e0b\u7ebf\u65f6\uff0c\u624d\u4f1a\u89e6\u53d1\u4e0a\u4e0b\u7ebf\u63d0\u9192\uff09\u3002\u540c\u65f6\u9700\u8981\u5c06\u5934\u50cf\u548c\u6635\u79f0\u653e\u5165 userData\uff0c\u5f53\u6211\u4eec\u6536\u5230\u4e00\u4e2a\u7528\u6237\u4e0a\u7ebf\u63d0\u9192\u7684\u65f6\u5019\uff0c\u6211\u4eec\u9700\u8981\u77e5\u9053\u8fd9\u4e2a\u7528\u6237\u7684\u5934\u50cf\u548c\u6635\u79f0\u3002</li>\n<li>\u521d\u59cb\u5316 onlineUsers\uff0conlineUsers \u662f\u7528\u6765\u5b58\u653e\u5f53\u524d\u804a\u5929\u5ba4\u5728\u7ebf\u7528\u6237\u6570\u548c\u5728\u7ebf\u7528\u6237\u5217\u8868\u3002 \u5c06\u5f53\u524d\u804a\u5929\u5ba4 Id (currentRoomId)\u4f5c\u4e3a channel,\u6267\u884c goEasy.hereNow \u67e5\u8be2\u6b64\u523b\u804a\u5929\u5ba4\u5728\u7ebf\u7528\u6237\u6570\u548c\u7528\u6237\u5217\u8868\uff0c\u8d4b\u503c\u7ed9 onlineUsers \u3002\u9664\u4e86\u5728\u8fdb\u5165\u804a\u5929\u5ba4\u7684\u65f6\u5019\u521d\u59cb\u5316 onlineUsers\uff0c\u5f53\u6709\u7528\u6237\u8fdb\u5165\u6216\u79bb\u5f00\u65f6\uff0c\u4e5f\u4f1a\u52a8\u6001\u7684\u66f4\u65b0 onlineUsers \u3002</li>\n<li>\u4ee5\u5f53\u524d\u804a\u5929\u5ba4\u7684 id(currentRoomId)\u4f5c\u4e3a channel\uff0c\u6267\u884c subscriber \u65b9\u6cd5\u76d1\u542c\u548c\u63a5\u6536\u804a\u5929\u5ba4\u65b0\u6d88\u606f\u3002</li>\n<li>\u4ee5\u5f53\u524d\u804a\u5929\u5ba4\u7684 id(currentRoomId)\u4f5c\u4e3a channel\uff0c\u6267\u884c subscriberPresence \u76d1\u542c\u7528\u6237\u8fdb\u5165\u548c\u79bb\u5f00\u4e8b\u4ef6\u3002</li>\n</ul>\n<p><strong>\u53c2\u8003\u4ee3\u7801\uff1aservice.js</strong></p>\n<pre><code>//\u521d\u59cb\u5316\u804a\u5929\u5ba4\nthis.joinRoom = function(userId,nickName, avatar, roomID) {\n        //\u521d\u59cb\u5316\u5f53\u524d\u7528\u6237\n        this.currentUser = new User(userId, nickName, avatar);\n        //\u521d\u59cb\u5316\u5f53\u524d\u804a\u5929\u5ba4 id\n        this.currentRoomId = roomID;\n        //\u521d\u59cb\u5316 goeasy\uff0c\u5efa\u7acb\u957f\u8fde\u63a5\n        this.goeasy = new GoEasy({\n            host: \"hangzhou.goeasy.io\",\n            appkey: \"\u60a8\u7684 appkey\",\n            userId: this.currentUser.id,\n            userData: '{\"nickname\":\"' + this.currentUser.nickname + '\",\"avatar\":\"' + this.currentUser.avatar + '\"}',\n            onConnected: function () {\n                console.log( \"GoEasy connect successfully.\")\n            },\n            onDisconnected: function () {\n                console.log(\"GoEasy disconnected.\")\n            }\n        });\n        //\u67e5\u8be2\u5f53\u524d\u5728\u7ebf\u7528\u6237\u5217\u8868\uff0c\u521d\u59cb\u5316 onlineUsers \u5bf9\u8c61\n        this.initialOnlineUsers();\n        //\u76d1\u542c\u7528\u6237\u4e0a\u4e0b\u7ebf\u63d0\u9192\uff0c\u5b9e\u65f6\u66f4\u65b0 onlineUsers \u5bf9\u8c61\n        this.subscriberPresence();\n        //\u76d1\u542c\u548c\u63a5\u6536\u65b0\u6d88\u606f\n        this.subscriberNewMessage();\n};\n</code></pre>\n<p><strong>2. \u9875\u9762\u5c55\u793a\uff1a</strong></p>\n<p>\u5b8c\u6210\u521d\u59cb\u5316\u4e4b\u540e\uff0c\u5c31\u8df3\u8f6c\u5230\u76f4\u64ad\u95f4\u754c\u9762\uff0c\u5728\u9875\u9762\u4e0a\u663e\u793a\u4ee5\u4e0b\u6570\u636e\uff1a</p>\n<ul>\n<li>\u5f53\u524d\u804a\u5929\u5ba4\u7684\u540d\u79f0</li>\n<li>\u804a\u5929\u8bb0\u5f55\uff0c\u5e76\u4e14\u663e\u793a\u804a\u5929\u5ba4\u754c\u9762</li>\n<li>\u5c55\u793a\u804a\u5929\u5ba4\u754c\u9762</li>\n</ul>\n<p><strong>\u53c2\u8003\u4ee3\u7801\uff1acontroller.js</strong></p>\n<pre><code>//\u9875\u9762\u5207\u6362\u5230\u804a\u5929\u5ba4\u754c\u9762\nfunction showChatRoom() {\n    //\u66f4\u65b0\u623f\u95f4\u540d\n    $(\"#chatRoom-header\").find(\".current-chatRoom-name\").text(loginCommand.roomName);\n\n    //\u52a0\u8f7d\u804a\u5929\u5386\u53f2\n    var chatHistory = service.loadChatHistory();\n    chatHistory.forEach(function (item) {\n        //\u5c55\u793a\u53d1\u9001\u7684\u6d88\u606f\n        var otherPerson = createCurrentChatRoomPerson(item.senderNickname + \":\", item.content)\n        $(\".chatRoom-content-box\").append($(otherPerson));\n    });\n\n    //\u9690\u85cf\u767b\u5f55\u754c\u9762\n    $(\".chat-login-box\").hide();\n    // //\u663e\u793a\u804a\u5929\u754c\u9762\n    $(\".chatRoom-box\").show();\n    // //\u6ed1\u52a8\u5230\u6700\u540e\u4e00\u884c\n    scrollBottom();\n}\n</code></pre>\n<p>\u81f3\u6b64\uff0c\u6211\u4eec\u5df2\u7ecf\u5b8c\u6210\u4e86 goeasy \u957f\u8fde\u63a5\u7684\u521d\u59cb\u5316\uff0c\u548c\u4e00\u4e2a\u804a\u5929\u5ba4\u9759\u6001\u5c55\u793a\u3002\u63a5\u4e0b\u6765\uff0c\u6211\u4eec\u4e00\u8d77\u6765\u770b\u770b\u5982\u4f55\u8ba9\u8fd9\u4e2a\u804a\u5929\u5ba4\u80fd\u591f\u52a8\u8d77\u6765\u3002</p>\n<h4>\u7b2c\u4e8c\u6b65\uff1a\u804a\u5929\u5ba4\u4e92\u52a8</h4>\n<p><strong>1. \u5b9e\u65f6\u66f4\u65b0\u5728\u7ebf\u7528\u6237\u6570\u548c\u5934\u50cf\u5217\u8868</strong></p>\n<p>\u4e4b\u524d\u5728 service.initialOnlineUsers \u65b9\u6cd5\u5df2\u7ecf\u521d\u59cb\u5316 onlineUsers \u5bf9\u8c61\uff0c\u4f46\u804a\u5929\u5ba4\u968f\u65f6\u90fd\u6709\u7528\u6237\u8fdb\u8fdb\u51fa\u51fa\uff0c\u6240\u4ee5\u6211\u4eec\u63a5\u4e0b\u6765\u8fd8\u9700\u8981\u80fd\u591f\u5728\u6709\u7528\u6237\u4e0a\u7ebf\u6216\u4e0b\u7ebf\u7684\u65f6\u5019\u80fd\u591f\u5b9e\u65f6\u7684\u66f4\u65b0 onlineUsers\uff0c\u5e76\u4e14\u5b9e\u65f6\u663e\u793a\u5728\u9875\u9762\u4e0a\u3002\n\u5f53\u6211\u4eec\u6536\u5230\u4e00\u4e2a\u7528\u6237\u4e0a\u7ebf\u63d0\u9192\uff0c\u6211\u4eec\u5c06\u65b0\u4e0a\u7ebf\u7684\u7528\u6237\u7684\u4fe1\u606f\u5b58\u5165\u5728\u7ebf\u7528\u6237\u5bf9\u8c61 onlineUsers \u91cc\uff0c\u5f53\u6709\u7528\u6237\u79bb\u5f00\u65f6\uff0c\u5728\u672c\u5730\u5728\u7ebf\u7528\u6237\u5217\u8868\u91cc\u5220\u9664\u3002</p>\n<p><strong>\u53c2\u8003\u4ee3\u7801\uff1aservice.js</strong></p>\n<pre><code>//\u76d1\u542c\u7528\u6237\u4e0a\u4e0b\u7ebf\u65f6\u95f4\uff0c\u7ef4\u62a4 onlineUsers \u5bf9\u8c61\nthis.subscriberPresence = function() {\n    var self = this;\n    this.goeasy.subscribePresence({\n        channel: this.currentRoomId,\n        onPresence: function(presenceEvents) {\n            presenceEvents.events.forEach(function(event) {\n                var userId = event.userId;\n                var count = presenceEvents.clientAmount;\n                //\u66f4\u65b0 onlineUsers \u5728\u7ebf\u7528\u6237\u6570\n                self.onlineUsers.count = count;\n                //\u5982\u679c\u6709\u7528\u6237\u8fdb\u5165\u804a\u5929\u5ba4\n                if (event.action == \"join\" || event.action == \"online\") {\n                    var userData = JSON.parse(event.userData);\n                    var nickName = userData.nickname;\n                    var avatar = userData.avatar;\n                    var user = new User(userId, nickName, avatar);\n                    //\u5c06\u65b0\u7528\u6237\u52a0\u5165 onlineUsers \u5217\u8868\n                    self.onlineUsers.users.push(user);\n                    //\u89e6\u53d1\u754c\u9762\u7684\u66f4\u65b0\n                    self.onJoinRoom(user.nickname, user.avatar);\n                } else {\n                    for (var i = 0; i &lt; self.onlineUsers.users.length; i++) {\n                        var leavingUser = self.onlineUsers.users[i];\n                        if (leavingUser.id == userId) {\n                            var nickName = leavingUser.nickname;\n                            var avatar = leavingUser.avatar;\n                            //\u5c06\u79bb\u5f00\u7684\u7528\u6237\u4ece onlineUsers \u4e2d\u5220\u6389\n                            self.onlineUsers.users.splice(i, 1);\n                            //\u89e6\u53d1\u754c\u9762\u7684\u66f4\u65b0\n                            self.onLeaveRoom(nickName, avatar);\n                        }\n                    }\n                }\n            });\n        },\n        onSuccess : function () {\n            console.log(\"\u76d1\u542c\u6210\u529f\")\n        },\n        onFailed : function () {\n            console.log(\"\u76d1\u542c\u5931\u8d25\")\n        }\n    });\n};\n</code></pre>\n<p><strong>2. \u53d1\u9001\u6d88\u606f</strong></p>\n<ul>\n<li>\u521d\u59cb\u5316\u4e00\u4e2a chatMessage \u5bf9\u8c61\uff0c\u5305\u542b\u53d1\u9001\u65b9 id\uff0c\u6635\u79f0\uff0c\u6d88\u606f\u5185\u5bb9\uff0c\u6d88\u606f\u7c7b\u578b\u4e3a chat</li>\n<li>\u5c06 chatMessage \u8f6c\u6362\u4e3a\u4e00\u4e2a Json \u683c\u5f0f\u7684\u5b57\u7b26\u4e32</li>\n<li>\u8c03\u7528 GoEasy \u7684 Publish \u65b9\u6cd5\uff0c\u5b8c\u6210\u6d88\u606f\u7684\u53d1\u9001</li>\n</ul>\n<p><strong>\u53c2\u8003\u4ee3\u7801\uff08 service.js)</strong></p>\n<pre><code>this.sendMessage = function(content) {\n    var message = new ChatMessage(this.currentUser.id,this.currentUser.nickname, MessageType.CHAT, content);\n    var self = this;\n    this.goeasy.publish({\n        channel: self.currentRoomId,\n        message: JSON.stringify(message),\n        onSuccess: function() {\n            console.log(\"\u6d88\u606f\u53d1\u5e03\u6210\u529f\u3002\");\n        },\n        onFailed: function(error) {\n            console.log(\"\u6d88\u606f\u53d1\u9001\u5931\u8d25\uff0c\u9519\u8bef\u7f16\u7801\uff1a\" + error.code + \" \u9519\u8bef\u4fe1\u606f\uff1a\" + error.content);\n        }\n    });\n};\n</code></pre>\n<p><strong>3. \u63a5\u6536\u548c\u663e\u793a\u65b0\u6d88\u606f /\u9053\u5177</strong></p>\n<p>\u4e4b\u524d\u6211\u4eec\u5df2\u7ecf\u5728\u521d\u59cb\u5316\u9875\u9762\u7684\u65f6\u5019\u6267\u884c\u4e86 service.subscriberNewMessage()\uff0c\u5f53\u6211\u4eec\u6536\u5230\u4e00\u6761\u6d88\u606f\u65f6\uff1a</p>\n<ul>\n<li>\u6839\u636e\u6d88\u606f\u7c7b\u578b\u5224\u65ad\u662f\u4e00\u6761\u804a\u5929\u6d88\u606f\uff0c\u8fd8\u662f\u4e00\u4e2a\u9053\u5177</li>\n<li>\u5982\u679c\u6536\u5230\u7684\u662f\u4e00\u6761\u804a\u5929\u6d88\u606f\uff0c\u76f4\u63a5\u663e\u793a\u5230\u754c\u9762</li>\n<li>\u5982\u679c\u662f\u9053\u5177\uff0c\u5c31\u64ad\u653e\u52a8\u753b</li>\n</ul>\n<p><strong>\u53c2\u8003\u4ee3\u7801\uff08 service.js \uff09</strong></p>\n<pre><code>//\u76d1\u542c\u6d88\u606f\u6216\u9053\u5177\nthis.subscriberNewMessage = function() {\n    var self = this;\n    this.goeasy.subscribe({\n        channel: this.currentRoomId, //\u66ff\u6362\u4e3a\u60a8\u81ea\u5df1\u7684 channel\n        onMessage: function(message) {\n            var chatMessage = JSON.parse(message.content);\n            //todo:\u4e8b\u5b9e\u4e0a\u4e0d\u63a8\u8350\u5728\u524d\u7aef\u6536\u5230\u65f6\u4fdd\u5b58, \u4e00\u4e2a\u7528\u6237\u5f00\u591a\u4e2a\u7a97\u53e3\uff0c\u4f1a\u5bfc\u81f4\u91cd\u590d\u4fdd\u5b58, \u5efa\u8bae\u6240\u6709\u6d88\u606f\u90fd\u662f\u90fd\u5728\u53d1\u9001\u65f6\u5728\u670d\u52a1\u5668\u7aef\u4fdd\u5b58\uff0c\u8fd9\u91cc\u53ea\u662f\u4e3a\u4e86\u6f14\u793a\n            self.restapi.saveChatMessage(self.currentRoomId, chatMessage);\n            //\u5982\u679c\u6536\u5230\u7684\u662f\u4e00\u4e2a\u6d88\u606f\uff0c\u5c31\u663e\u793a\u4e3a\u6d88\u606f\n            if (chatMessage.type == MessageType.CHAT) {\n                var selfSent = chatMessage.senderUserId == self.currentUser.id;\n                var content = JSON.parse(message.content);\n                self.onNewMessage(chatMessage.senderNickname, content, selfSent);\n            }\n            //\u5982\u679c\u6536\u5230\u7684\u662f\u4e00\u4e2a\u9053\u5177\uff0c\u5c31\u64ad\u653e\u9053\u5177\u52a8\u753b\n            if (chatMessage.type == MessageType.PROP) {\n                if (chatMessage.content == Prop.ROCKET) {\n                    self.onNewRocket(chatMessage.senderNickname);\n                }\n                if (chatMessage.content == Prop.HEART) {\n                    self.onNewHeart(chatMessage.senderNickname);\n                }\n            }\n        }\n    });\n};\n</code></pre>\n<p><strong>4. \u53d1\u9001\u548c\u63a5\u6536\u5e76\u5c55\u793a\u9053\u5177</strong></p>\n<p>\u5176\u5b9e\u548c\u53d1\u9001\u6d88\u606f\u7684\u5b9e\u73b0\u51e0\u4e4e\u662f\u4e00\u6837\u7684\uff0c\u5177\u4f53\u4ee3\u7801\u8bf7\u53c2\u8003 service.js \u7684 sendProp \u65b9\u6cd5\uff0ccontroller.js \u7684 onNewHeart()\u65b9\u6cd5\u3002\u52a8\u753b\u7684\u64ad\u653e\uff0c\u4f7f\u7528\u4e86 TweenMax \u8fd9\u4e2a\u5e93\uff0c\u4e3b\u8981\u662f\u4e3a\u4e86\u5c55\u793a\u4e00\u4e2a\u5b9e\u73b0\u601d\u8def\uff0c\u5c0f\u7f16\u4e5f\u4e0d\u77e5\u9053\u8fd9\u4e2a\u5e93\u662f\u5426\u6709\u5f88\u597d\u7684\u517c\u5bb9\u6027\uff0c\u4ee5\u53ca\u662f\u5426\u80fd\u591f\u7528\u5728 Uniapp \u548c\u5c0f\u7a0b\u5e8f\u4e0b\uff0c\u77e5\u9053\u7684\u670b\u53cb\u53ef\u4ee5\u7559\u8a00\u5206\u4eab\u7ed9\u5927\u5bb6\u3002</p>\n<pre><code>this.sendProp = function(prop) {\n    var self = this;\n    var message = new ChatMessage(this.currentUser.id,this.currentUser.nickname, MessageType.PROP, prop);\n    this.goeasy.publish({\n        channel: self.currentRoomId,\n        message: JSON.stringify(message),\n        onSuccess: function() {\n            console.log(\"\u9053\u5177\u53d1\u5e03\u6210\u529f\u3002\");\n        },\n        onFailed: function(error) {\n            console.log(\"\u9053\u5177\u53d1\u9001\u5931\u8d25\uff0c\u9519\u8bef\u7f16\u7801\uff1a\" + error.code + \" \u9519\u8bef\u4fe1\u606f\uff1a\" + error.content);\n        }\n    });\n};\n</code></pre>\n<p>\u81f3\u6b64\uff0c\u4e00\u4e2a\u804a\u5929\u5ba4\u5c31\u641e\u5b9a\u4e86\uff0c\u662f\u4e0d\u662f\u5f88\u7b80\u5355\uff1f</p>\n<p>\u5982\u679c\u9605\u8bfb\u672c\u6587\u6216\u5f00\u53d1\u4e2d\u6709\u4efb\u4f55\u95ee\u9898\uff0c\u4e5f\u6b22\u8fce\u5728 GoEasy \u5b98\u7f51\u6dfb\u52a0 GoEasy \u4e3a\u597d\u53cb\uff0c\u6765\u83b7\u5f97\u66f4\u591a\u6280\u672f\u652f\u6301\u3002</p>\n<p>GoEasy \u5b98\u7f51\uff1a<a href=\"https://www.goeasy.io/\" rel=\"nofollow\">https://www.goeasy.io/</a></p>\n"
    }, 
    {
      "author": {
        "url": "https://www.v2ex.com/member/jonychen1", 
        "name": "jonychen1", 
        "avatar": "https://cdn.v2ex.com/gravatar/e88d31c5f54b66367a32a1877e5d100e?s=73&d=retro"
      }, 
      "url": "https://www.v2ex.com/t/655594", 
      "date_modified": "2020-03-24T02:35:35+00:00", 
      "content_html": "<p>Uniapp \u4f5c\u4e3a\u8fd1\u6765\u6700\u706b\u7684\u79fb\u52a8\u7aef\u5f00\u53d1\u6280\u672f\uff0c\u4e00\u5957\u4ee3\u7801\uff0c\u53ef\u4ee5\u6253\u5305\u6210 Android/iOS app \u548c\u5404\u79cd\u5e73\u53f0\u7684\u5c0f\u7a0b\u5e8f\uff0c\u53ef\u8c13\u662f\u6ca1\u6709\u6700\u65b9\u4fbf\u53ea\u6709\u66f4\u65b9\u4fbf\u3002</p>\n<p>GoEasy \u4e0a\u67b6 DCloud Uniapp \u63d2\u4ef6\u5e02\u573a\u5df2\u7ecf\u6709\u4e00\u4e2a\u591a\u6708\u4e86\uff0c\u6536\u5230\u5f88\u591a Uniapp \u5f00\u53d1\u4eba\u5458\u7684\u8d5e\u626c\u548c\u597d\u8bc4\uff0c\u5c0f\u7f16\u5728\u6b64\u9694\u7740\u5c4f\u5e55\u5411\u5927\u5bb6\u97a0\u8eac\uff0c\u5c0f\u7f16\u548c GoEasy \u56e2\u961f\u4f1a\u7ee7\u7eed\u52aa\u529b\uff0c\u6301\u7eed\u4e3a Uniapp \u5f00\u53d1\u8005\u63d0\u4f9b\u6700\u7b80\u5355\u4e14\u4f18\u96c5\u7684 API\uff0c\u7a33\u5b9a\u9ad8\u901f\u53ef\u9760\u7684\u5373\u65f6\u901a\u8baf\u670d\u52a1\u3002</p>\n<p>\u8fd9\u6bb5\u65f6\u95f4\uff0c\u4e5f\u6536\u5230\u4e86\u5f88\u591a\u670b\u53cb\u7684\u4e00\u4e9b\u95ee\u9898\uff1f\u6bd4\u5982\uff1a</p>\n<p><strong>1 \u3001GoEasy \u548c Uniapp websocket API \u6709\u4ec0\u4e48\u533a\u522b\u548c\u4f18\u52bf\uff1f</strong></p>\n<p>Uniapp \u5b98\u65b9\u7684 websocket API \u4e3b\u8981\u662f\u7528\u6765\u4e0e\u60a8\u7684 websocket \u670d\u52a1\u901a\u8baf\uff0c\u6240\u4ee5\u4f7f\u7528 Uniapp websocket \u7684\u524d\u63d0\u662f\uff0c\u9996\u5148\u8981\u642d\u5efa\u597d\u60a8\u81ea\u5df1\u7684 websocket \u670d\u52a1\uff0c\u7136\u540e\u4e0e\u4e4b\u901a\u8baf\u3002\u8fd9\u662f\u4e00\u4e2a\u7eaf\u6280\u672f\u7684 API\uff0c\u5728\u5efa\u7acb\u7f51\u7edc\u8fde\u63a5\u540e\uff0c\u8fd8\u6709\u5f88\u591a\u7684\u5de5\u4f5c\u9700\u8981\u81ea\u5df1\u6765\u5b8c\u6210\uff0c\u6bd4\u5982\uff1a</p>\n<p>\u9700\u8981\u81ea\u5df1\u5b9e\u73b0\u5fc3\u8df3\u673a\u5236\uff0c\u6765\u7ef4\u62a4\u7f51\u7edc\u8fde\u63a5\uff0c\u6765\u5224\u65ad\u5ba2\u6237\u7aef\u7684\u7f51\u7edc\u8fde\u63a5\u72b6\u6001\uff1b\n\u9700\u8981\u81ea\u5df1\u5b9e\u73b0\u65ad\u7f51\u81ea\u52a8\u91cd\u8fde\uff1b\n\u9700\u8981\u81ea\u5df1\u7ef4\u62a4\u6d88\u606f\u5217\u8868\uff0c\u786e\u4fdd\u9047\u5230\u65ad\u7f51\u91cd\u8fde\u540e\uff0c\u6d88\u606f\u80fd\u591f\u8865\u53d1\uff1b\n\u9700\u8981\u81ea\u5df1\u7ef4\u62a4\u4e00\u4e2a\u5ba2\u6237\u7aef\u5217\u8868\uff1b\n...\n\u7b49\u7b49\u5f88\u591a\u7ec6\u81f4\u800c\u7e41\u6742\u7684\u5de5\u4f5c\uff0c\u6bd4\u5982 websocket \u7684\u5b89\u5168\u673a\u5236\u548c\u6027\u80fd\u4f18\u5316\uff1b\n\u9664\u6b64\u4e4b\u5916\u670d\u52a1\u7aef\u4e5f\u6709\u5f88\u591a\u5de5\u4f5c\u9700\u8981\u81ea\u5df1\u5b8c\u6210\uff0c\u6709\u5174\u8da3\u81ea\u5df1\u642d\u5efa websocket \u7684\u8bdd\uff0c\u53ef\u4ee5\u53c2\u8003\u8fd9\u7bc7\u6280\u672f\u5206\u4eab\u300a<a href=\"https://www.v2ex.com/t/651558\" rel=\"nofollow\">\u642d\u5efa websocket \u6d88\u606f\u63a8\u9001\u670d\u52a1\uff0c\u5fc5\u987b\u8981\u8003\u8651\u7684\u51e0\u4e2a\u95ee\u9898</a>\u300b</p>\n<p>\u800c GoEasy \u662f\u4e00\u4e2a\u6210\u719f\u7a33\u5b9a\u7684 websocket \u4f01\u4e1a\u7ea7 PAAS \u670d\u52a1\u5e73\u53f0\uff0c\u5f00\u53d1\u4eba\u5458\u4e0d\u9700\u8981\u8003\u8651 websocket \u670d\u52a1\u7aef\u7684\u642d\u5efa\uff0c\u53ea\u9700\u8981\u51e0\u884c\u4ee3\u7801\uff0c\u5c31\u53ef\u4ee5\u8f7b\u677e\u5b9e\u73b0\u5ba2\u6237\u7aef\u4e0e\u5ba2\u6237\u7aef\u4e4b\u95f4\uff0c\u670d\u52a1\u5668\u4e0e\u5ba2\u6237\u7aef\u4e4b\u95f4\u7684\u7684 websocket \u901a\u4fe1\uff0c\u4e0d\u9700\u8981\u8003\u8651\u6027\u80fd\uff0c\u5b89\u5168\uff0c\u9ad8\u53ef\u7528\u96c6\u7fa4\u7684\u95ee\u9898\u3002\u53ea\u9700\u8981\u5168\u529b\u4e13\u6ce8\u4e8e\u5f00\u53d1\u81ea\u5df1\u7684\u4e1a\u52a1\u529f\u80fd\u5c31\u597d\u4e86\u3002</p>\n<p>GoEasy \u5df2\u7ecf\u5185\u7f6e websocket \u4e2d\u5fc5\u5907\u7684\u5fc3\u8df3\uff0c\u65ad\u7f51\u91cd\u8fde\uff0c\u6d88\u606f\u8865\u53d1\uff0c\u5386\u53f2\u6d88\u606f\u548c\u5ba2\u6237\u7aef\u4e0a\u4e0b\u7ebf\u63d0\u9192\u7b49\u7279\u6027\uff0c\u5f00\u53d1\u4eba\u5458\u4e5f\u4e0d\u9700\u8981\u81ea\u5df1\u642d\u5efa websocket \u670d\u52a1\u5904\u7406\u96c6\u7fa4\u9ad8\u53ef\u7528\uff0c\u5b89\u5168\u548c\u6027\u80fd\u95ee\u9898\u3002GoEasy \u5df2\u7ecf\u7a33\u5b9a\u8fd0\u884c\u4e86 5 \u5e74\uff0c\u652f\u6301\u5343\u4e07\u7ea7\u5e76\u53d1\uff0c\u6210\u529f\u652f\u6491\u8fc7\u5f88\u591a\u77e5\u540d\u4f01\u4e1a\u7684\u91cd\u8981\u6d3b\u52a8\uff0c\u5b89\u5168\u6027\u548c\u53ef\u9760\u6027\u90fd\u662f\u4e45\u7ecf\u8003\u9a8c\u3002</p>\n<p><strong>2 \u3001GoEasy \u5728 Uniapp \u5f00\u53d1\u4e2d\u4e3b\u8981\u7528\u5728\u54ea\u4e9b\u573a\u666f\u5462\uff1f</strong></p>\n<p>\u9996\u5148\u4ece\u6280\u672f\u4e0a\u8bf4\uff0cUniapp \u652f\u6301\u7684\u6240\u6709\u6280\u672f android, iOS \u548c\u5c0f\u7a0b\u5e8f\uff0cGoEasy \u90fd\u662f\u5b8c\u7f8e\u652f\u6301\u7684\u3002</p>\n<p>\u4ece\u5e94\u7528\u573a\u666f\u4e0a\u6765\u8bf4\uff0c\u6240\u6709\u9700\u8981 websocket \u901a\u4fe1\u7684\u573a\u666f\uff0cGoEasy \u90fd\u53ef\u4ee5\u5b8c\u7f8e\u652f\u6301\uff1a</p>\n<p>\u804a\u5929\uff0cIM\uff0c\u76f4\u64ad\u5f39\u5e55\uff0c\u7528\u6237\u4e0a\u4e0b\u7ebf\u63d0\u9192, \u5728\u7ebf\u7528\u6237\u5217\u8868\n\u626b\u7801\u70b9\u83dc\uff0c\u626b\u7801\u767b\u5f55\uff0c \u626b\u7801\u652f\u4ed8\uff0c \u626b\u7801\u7b7e\u5230\uff0c \u626b\u7801\u6253\u5370\n\u4e8b\u4ef6\u63d0\u9192\uff0c\u5de5\u5355\uff0c\u8ba2\u5355\u5b9e\u65f6\u63d0\u9192\n\u5728\u7ebf\u62cd\u5356\uff0c \u5728\u7ebf\u70b9\u9910\uff0c\u5728\u7ebf\u9009\u5ea7 \u5b9e\u65f6\u6570\u636e\u5c55\u793a\uff0c\u5b9e\u65f6\u76d1\u63a7\u5927\u5c4f\uff0c \u91d1\u878d\u5b9e\u65f6\u884c\u60c5\u663e\u793a\uff0c\u8bbe\u5907\u76d1\u63a7\u7cfb\u7edf\n\u5b9e\u65f6\u4f4d\u7f6e\u8ddf\u8e2a\uff0c\u5916\u5356\u5b9e\u65f6\u8ddf\u8e2a\uff0c\u7269\u6d41\u5b9e\u65f6\u8ddf\u8e2a\n\u8fdc\u7a0b\u753b\u677f\uff0c\u8fdc\u7a0b\u533b\u7597\uff0c\u6e38\u620f\uff0c\u8fdc\u7a0b\u5728\u7ebf\u6388\u8bfe\n...</p>\n<p><strong>3 \u3001GoEasy \u7684\u6587\u6863\u4e3a\u4ec0\u4e48\u8fd9\u4e48\u7b80\u5355\uff1f\u7b80\u5355\u5230\u6211\u90fd\u4e0d\u77e5\u9053\u5982\u4f55\u4f7f\u7528</strong></p>\n<p>\u7b80\u5355\u8fd8\u4e0d\u597d\u5417\uff1f GoEasy \u4ece\u7814\u53d1\u7684\u7b2c\u4e00\u5929\uff0c\u5c31\u628a\u8ffd\u6c42 API \u7684\u6781\u7b80\u4f5c\u4e3a\u6211\u4eec\u7684\u5de5\u4f5c\u91cd\u70b9\u3002\u4e25\u683c\u63a7\u5236\u63a5\u53e3\u7684\u6570\u91cf\uff0c\u5c31\u662f\u662f\u4e3a\u4e86\u964d\u4f4e\u5f00\u53d1\u4eba\u5458\u7684\u5b66\u4e60\u6210\u672c\uff0c\u5176\u5b9e\u5c31\u662f\u4e3a\u4e86\u8ba9\u60a8\u723d\u554a\uff01\u4f46\u8fd9\u5e76\u4e0d\u5f71\u54cd GoEasy \u5b8c\u7f8e\u652f\u6301\u6240\u6709\u7684 websocket \u5373\u65f6\u901a\u8baf\u9700\u6c42\u3002</p>\n<p>\u4eca\u5929\u5c0f\u7f16\u5c31\u624b\u628a\u624b\u7684\u6559\u60a8\u7528 GoEasy \u5728 Uniapp \u4e0b\uff0c\u6700\u77ed\u7684\u65f6\u95f4\u5b9e\u73b0\u4e00\u4e2a\u7684 web \u5373\u65f6\u901a\u8baf Demo \u3002\n<img alt=\"image\" src=\"https://img2020.cnblogs.com/blog/1950813/202003/1950813-20200323172331236-977870287.jpg\"/></p>\n<p>\u672c demo \u5df2\u7ecf\u901a\u8fc7\u5c0f\u7a0b\u5e8f, iOS \u548c Android \u7684\u771f\u673a\u6d4b\u8bd5\uff0c\u5b8c\u6574\u6e90\u4ee3\u7801\u5df2\u7ecf\u4e0a\u4f20 github\uff0c\u4e0b\u8f7d\u540e\uff0c\u53ea\u9700\u8981\u5c06\u4ee3\u7801\u91cc\u7684 appkey \u6362\u6210\u81ea\u5df1\u7684 common key\uff0c\u5c31\u53ef\u4ee5\u4f53\u9a8c\u4e86\u3002\u4e0b\u8f7d\u5730\u5740\uff1a</p>\n<p><a href=\"https://github.com/GoEasySupport/goeasy-uniapp-helloworld\" rel=\"nofollow\">https://github.com/GoEasySupport/goeasy-uniapp-helloworld</a></p>\n<p><strong>1 \u3001\u83b7\u53d6 appkey</strong></p>\n<p>GoEasy \u5b98\u7f51(<a href=\"https://www.goeasy.io/\" rel=\"nofollow\">https://www.goeasy.io/</a>)\u4e0a\u6ce8\u518c\u8d26\u53f7\uff0c\u521b\u5efa\u4e00\u4e2a\u5e94\u7528\uff0c\u62ff\u5230\u60a8\u7684 appkey</p>\n<p><img alt=\"image\" src=\"https://img2020.cnblogs.com/blog/1950813/202003/1950813-20200323171720567-26775819.png\"/></p>\n<p>GoEasy \u63d0\u4f9b\u4e86\u4e24\u79cd\u7c7b\u578b\u7684 appkey\uff1a</p>\n<p>Common key: \u5373\u53ef\u4ee5\u63a5\u6536\u6d88\u606f\uff0c\u4e5f\u53ef\u4ee5\u53d1\u9001\u6d88\u606f\uff0c\u4e0e Subscriber Key \u6700\u5927\u7684\u533a\u522b\u5c31\u662f\u6709\u5199\u6743\u9650\uff0c\u53ef\u4ee5\u53d1\u6d88\u606f\u3002\u9002\u7528\u4e8e\u6709\u6d88\u606f\u53d1\u9001\u9700\u6c42\u7684\u5ba2\u6237\u7aef\u548c\u670d\u52a1\u7aef\u5f00\u53d1\u3002</p>\n<p>Subscriber key: \u53ea\u80fd\u63a5\u6536\u6d88\u606f\uff0c\u4e0d\u53ef\u4ee5\u53d1\u9001\u6d88\u606f\uff0c\u4e0e Common Key \u6700\u5927\u7684\u533a\u522b\u5c31\u662f\u6ca1\u6709\u5199\u6743\u9650\uff0c\u53ea\u80fd\u6536\u6d88\u606f\u3002\u53ef\u4ee5\u7528\u4e8e\u4e00\u4e9b\u6ca1\u6709\u53d1\u9001\u9700\u6c42\u7684\u5ba2\u6237\u7aef\u3002</p>\n<p><strong>2 \u3001\u83b7\u53d6 GoEasy SDK</strong></p>\n<p>\u4e24\u4e2a\u65b9\u5f0f\uff1a</p>\n<p>DCloud Uniapp \u7684\u63d2\u4ef6\u5e02\u573a\u4e0b\u8f7d\uff1a<a href=\"https://ext.dcloud.net.cn/plugin?id=1334\" rel=\"nofollow\">https://ext.dcloud.net.cn/plugin?id=1334</a></p>\n<p>\u4e5f\u53ef\u4ee5\u76f4\u63a5\u5728 goeasy \u5b98\u7f51\u4e0b\u8f7d\uff1a<a href=\"https://www.goeasy.io/cn/doc/client/get-goeasy-js.html\" rel=\"nofollow\">https://www.goeasy.io/cn/doc/client/get-goeasy-js.html</a></p>\n<p><strong>3 \u3001\u521d\u59cb\u5316 GoEasy \u5bf9\u8c61</strong></p>\n<p>\u5728 main.js \u4e2d\u5c06 goeasy \u521d\u59cb\u5316\u4e3a Uniapp \u7684\u5168\u5c40\u5bf9\u8c61\uff0c\u65b9\u4fbf\u6240\u6709\u9875\u9762\u90fd\u80fd\u65b9\u4fbf\u7684\u8c03\u7528\uff0c\u540c\u65f6\u4e5f\u907f\u514d\u591a\u4e2a\u9875\u9762\u53cd\u590d new GoEasy \u5bf9\u8c61\u3002</p>\n<p>\u6839\u636e\u60a8\u5728 GoEasy \u540e\u53f0\u521b\u5efa\u5e94\u7528\u65f6\u9009\u62e9\u7684\u533a\u57df\uff0c\u6765\u4f20\u5165\u4e0d\u540c\u7684 Host,\u5982\u679c\u60a8\u521b\u5efa goeasy \u5e94\u7528\u65f6,\u9009\u62e9\u4e86\u676d\u5dde\uff0c\u90a3\u4e48 host:\"<a href=\"http://hangzhou.goeasy.io\" rel=\"nofollow\">hangzhou.goeasy.io</a>\"\u3002\u9009\u62e9\u4e86\u65b0\u52a0\u5761,host:\"<a href=\"http://singapore.goeasy.io\" rel=\"nofollow\">singapore.goeasy.io</a>\"\u3002</p>\n<p>\u5982\u679c\u60a8\u7684\u5927\u90e8\u5206\u7528\u6237\u90fd\u662f\u5728\u56fd\u5185\uff0c\u521b\u5efa\u5e94\u7528\u65f6\uff0c\u8bb0\u5f97\u9009\u62e9\u676d\u5dde\uff0c\u4ee5\u4fbf\u83b7\u5f97\u66f4\u5feb\u7684\u901a\u8baf\u901f\u5ea6\u3002</p>\n<pre><code>// \u5728 main.js \u4e2d\u5c06 goeasy \u521d\u59cb\u5316\u4e3a\u5168\u5c40\u5bf9\u8c61\uff0c\u6240\u6709\u9875\u9762\u90fd\u80fd\u65b9\u4fbf\u7684\u8c03\u7528\uff0c\u4e5f\u907f\u514d\u591a\u4e2a\u9875\u9762\u53cd\u590d new GoEasy \u5bf9\u8c61\nVue.prototype.$goEasy = new GoEasy({\nhost: \"hangzhou.goeasy.io\",\nappkey: \"my_appkey\", //\u66ff\u6362\u4e3a\u60a8\u7684\u5e94\u7528 appkey\n    onConnected: function() {\n      console.log('\u8fde\u63a5\u6210\u529f\uff01')\n    },\n    onDisconnected: function() {\n      console.log('\u8fde\u63a5\u65ad\u5f00\uff01')\n    },\n    onConnectFailed: function(error) {\n      console.log('\u8fde\u63a5\u5931\u8d25\u6216\u9519\u8bef\uff01')\n    }\n});\n</code></pre>\n<p><strong>4 \u3001uniapp \u7aef\u63a5\u6536\u6d88\u606f</strong></p>\n<pre><code>this.$goEasy.subscribe({\n    channel: \"my_channel\", //\u66ff\u6362\u4e3a\u60a8\u81ea\u5df1\u7684 channel\n    onMessage: function (message) {\n        alert(\"Channel:\" + message.channel + \" content:\" + message.content);\n    }\n});\n</code></pre>\n<p>\u5f88\u591a\u670b\u53cb\u4f1a\u95ee channel \u4ece\u54ea\u91cc\u6765\uff0c\u5982\u4f55\u521b\u5efa\uff0c\u5e94\u8be5\u4f20\u5165\u4ec0\u4e48\u5462\uff1f</p>\n<p>\u6839\u636e\u60a8\u7684\u4e1a\u52a1\u9700\u6c42\u6765\u8bbe\u5b9a\uff0cchannel \u53ef\u4ee5\u4e3a\u4efb\u610f\u5b57\u7b26\u4e32\uff0c\u9664\u4e86\u4e0d\u80fd\u5305\u542b\u7a7a\u683c\uff0c\u548c\u4e0d\u5efa\u8bae\u4f7f\u7528\u4e2d\u6587\u5916\uff0c\u6ca1\u6709\u4efb\u4f55\u9650\u5236\uff0c\u53ea\u9700\u8981\u548c\u6d88\u606f\u7684\u53d1\u9001\u7aef\u4fdd\u6301\u4e00\u81f4\uff0c\u5c31\u53ef\u4ee5\u6536\u5230\u6d88\u606f\u3002channel \u53ef\u4ee5\u662f\u60a8\u76f4\u64ad\u95f4\u7684 uuid,\u4e5f\u53ef\u4ee5\u662f\u4e00\u4e2a\u7528\u6237\u7684\u552f\u4e00\u8868\u793a\u7b26\uff0c\u53ef\u4ee5\u4efb\u610f\u5b9a\u4e49\uff0cchannel \u4e0d\u9700\u8981\u521b\u5efa\uff0c\u53ef\u4ee5\u968f\u7528\u968f\u5f03\u3002</p>\n<p><strong>5 \u3001uniapp \u7aef\u53d1\u9001\u6d88\u606f</strong></p>\n<p>\u53d1\u9001\u65f6\uff0c\u9700\u8981\u6ce8\u610f channel \u4e00\u5b9a\u8981\u548c subscriber \u7684 channel \u5b8c\u5168\u4e00\u81f4\uff0c\u5426\u5219\u65e0\u6cd5\u6536\u5230\u3002</p>\n<pre><code>this.$goEasy.publish({\n    channel: \"my_channel\", //\u66ff\u6362\u4e3a\u60a8\u81ea\u5df1\u7684 channel\n    message: \"Hello, GoEasy!\" //\u66ff\u6362\u4e3a\u60a8\u60f3\u8981\u53d1\u9001\u7684\u6d88\u606f\u5185\u5bb9\n});\n\n</code></pre>\n<p>\u672c\u4ee3\u7801\u6e90\u7801\u4e0b\u8f7d\uff1a</p>\n<p><a href=\"https://github.com/GoEasySupport/goeasy-uniapp-helloworld\" rel=\"nofollow\">https://github.com/GoEasySupport/goeasy-uniapp-helloworld</a></p>\n<p><strong>\u5c0f\u7a0b\u5e8f\u7279\u522b\u5f3a\u8c03\uff1a</strong></p>\n<p>\u82e5\u60a8\u9700\u8981\u6253\u5305\u4e3a\u5fae\u4fe1\u5c0f\u7a0b\u5e8f\uff0c\u9700\u8981\u5728\u5fae\u4fe1\u516c\u4f17\u53f7\u5e73\u53f0\u914d\u7f6e socket \u5408\u6cd5\u57df\u540d\uff0c\u5426\u5219\u65e0\u6cd5\u4f7f\u7528\u3002 \u5177\u4f53\u6b65\u9aa4\uff1a</p>\n<p>\u8bbf\u95ee <a href=\"https://mp.weixin.qq.com\" rel=\"nofollow\">https://mp.weixin.qq.com</a> \uff0c\u8fdb\u5165\u5fae\u4fe1\u516c\u4f17\u5e73\u53f0|\u5c0f\u7a0b\u5e8f -&gt; \u8bbe\u7f6e -&gt; \u5f00\u53d1\u8bbe\u7f6e -&gt; \u670d\u52a1\u5668\u57df\u540d</p>\n<p>socket \u5408\u6cd5\u57df\u540d-&gt; \u6dfb\u52a0 goeasy \u7684\u5730\u5740\uff1a<a href=\"http://wx-hangzhou.goeasy.io\" rel=\"nofollow\">wx-hangzhou.goeasy.io</a> \uff08\u8bb0\u5f97 wx-\u5f00\u5934\uff09</p>\n<p>\u82e5\u60a8\u521b\u5efa GoEasy \u5e94\u7528\u65f6\u9009\u62e9\u4e86\u65b0\u52a0\u5761\u533a\u57df\u5219\u6dfb\u52a0\u5730\u5740\uff1a<a href=\"http://wx-singapore.goeasy.io\" rel=\"nofollow\">wx-singapore.goeasy.io</a></p>\n<p><strong>\u7b54\u7591\u65f6\u95f4\uff1a</strong></p>\n<p>1 \u3001\u6211\u7684\u670d\u52a1\u5668\u7aef\u53ef\u4ee5\u53d1\u9001\u6d88\u606f\u5417\uff1f\u90fd\u652f\u6301\u4e9b\u54ea\u4e9b\u8bed\u8a00\uff1f</p>\n<p>\u5f53\u7136\u53ef\u4ee5\uff0c\u4efb\u4f55\u8bed\u8a00\u90fd\u53ef\u4ee5\u901a\u8fc7\u8c03\u7528 goeasy \u7684 Rest API \u53d1\u9001\u6d88\u606f\uff0c\u540c\u65f6\u4e3a\u4e86\u5927\u5bb6\u65b9\u4fbf\uff0cGoEasy \u7684\u5b98\u65b9\u6587\u6863\u91cc\uff0c\u4e5f\u51c6\u5907\u4e86 Java, C#,NodeJS\uff0cPHP\uff0cRuby \u548c Python \u7b49\u5e38\u89c1\u8bed\u8a00\u8c03\u7528 REST API \u7684\u4ee3\u7801\uff0c\u8fd9\u91cc\u83b7\u53d6\u66f4\u591a\u8be6\u60c5\uff1a<a href=\"https://www.goeasy.io/cn/doc/server/publish.html\" rel=\"nofollow\">https://www.goeasy.io/cn/doc/server/publish.html</a></p>\n<p>2 \u3001GoEasy \u53ef\u4ee5\u53d1\u9001\u56fe\u7247\uff0c\u8bed\u97f3\u548c\u89c6\u9891\u5417\uff1f</p>\n<p>\u5f53\u7136\u53ef\u4ee5\uff0c\u60a8\u53ef\u4ee5\u901a\u8fc7\u63a8\u9001\u6587\u4ef6\u8def\u5f84\u7684\u65b9\u5f0f\u6765\u5b9e\u73b0\u6587\u4ef6\u7684\u53d1\u9001\u3002</p>\n<p>\u6309\u7167\u884c\u4e1a\u60ef\u4f8b\uff0c\u4e0d\u8bba MSN\uff0c\u5fae\u4fe1\uff0cQQ \u5bf9\u4e8e\u56fe\u7247\u548c\u89c6\u9891\uff0c\u901a\u5e38\u7684\u505a\u6cd5\u90fd\u662f\uff0c\u53ea\u63a8\u9001\u6587\u4ef6\u8def\u5f84\uff0c\u800c\u4e0d\u4f1a\u63a8\u9001\u6587\u4ef6\u672c\u8eab\u3002\u4f60\u5982\u679c\u6709\u6ce8\u610f\u7684\u8bdd\uff0c\u5f53\u60a8\u63a5\u53d7\u56fe\u7247\u548c\u89c6\u9891\u7684\u65f6\u5019\uff0c\u6536\u5230\u6d88\u606f\u540e\uff0c\u7b49\u4e00\u4f1a\u513f\u624d\u80fd\u770b\uff0c\u5c31\u662f\u56e0\u4e3a\u53d1\u9001\u7684\u65f6\u5019\uff0c\u53ea\u53d1\u9001\u4e86\u8def\u5f84\u3002</p>\n", 
      "date_published": "2020-03-24T02:28:50+00:00", 
      "title": "Uniapp \u4f7f\u7528 GoEasy \u5b9e\u73b0 websocket \u5b9e\u65f6\u901a\u8baf", 
      "id": "https://www.v2ex.com/t/655594"
    }, 
    {
      "author": {
        "url": "https://www.v2ex.com/member/jonychen1", 
        "name": "jonychen1", 
        "avatar": "https://cdn.v2ex.com/gravatar/e88d31c5f54b66367a32a1877e5d100e?s=73&d=retro"
      }, 
      "url": "https://www.v2ex.com/t/651558", 
      "title": "\u642d\u5efa websocket \u6d88\u606f\u63a8\u9001\u670d\u52a1\uff0c\u5fc5\u987b\u8981\u8003\u8651\u7684\u51e0\u4e2a\u95ee\u9898", 
      "id": "https://www.v2ex.com/t/651558", 
      "date_published": "2020-03-10T08:17:36+00:00", 
      "content_html": "<p>\u8fd1\u5e74\uff0c\u4e0d\u8bba\u662f\u6b63\u5728\u5feb\u901f\u589e\u957f\u7684\u76f4\u64ad\uff0c\u8fdc\u7a0b\u6559\u80b2\u4ee5\u53ca IM \u804a\u5929\u573a\u666f\uff0c\u8fd8\u662f\u5728\u5e38\u89c4\u4f01\u4e1a\u7ea7\u7cfb\u7edf\u4e2d\u7528\u5230\u7684\u7cfb\u7edf\u63d0\u9192\uff0c\u5bf9 websocket \u7684\u9700\u6c42\u8d8a\u6765\u8d8a\u5927\uff0c\u5bf9 websocket \u7684\u8981\u6c42\u4e5f\u8d8a\u6765\u8d8a\u9ad8\u3002\u4ece\u65e9\u671f\u5bf9 websocket \u7684\u5e94\u7528\u4ec5\u9650\u4e8e\u5c11\u90e8\u5206\u529f\u80fd\u548c IM \u7b49\u7279\u6b8a\u573a\u666f\uff0c\u9010\u6b65\u53d1\u5c55\u4e3a\u8ffd\u6c42\u652f\u6301\u9ad8\u5e76\u53d1\uff0c\u767e\u4e07\u3001\u5343\u4e07\u7ea7\u6bcf\u79d2\u901a\u8baf\u7684\u9ad8\u53ef\u7528 websocket \u670d\u52a1\u3002</p>\n<p>\u9762\u5bf9\u5404\u79cd\u65b0\u573a\u666f\u5bf9 websocket \u529f\u80fd\u548c\u6027\u80fd\u8d8a\u6765\u8d8a\u9ad8\u7684\u9700\u6c42\uff0c\u4e0d\u540c\u7684\u56e2\u961f\u6709\u4e0d\u540c\u7684\u9009\u62e9\uff0c\u6709\u7684\u76f4\u63a5\u4f7f\u7528\u7531\u4e13\u4e1a\u56e2\u961f\u5f00\u53d1\u7684\u6210\u719f\u7a33\u5b9a\u7684\u7b2c\u4e09\u65b9 websocket \u670d\u52a1\uff0c\u6709\u4e9b\u5219\u9009\u62e9\u81ea\u5efa websocket \u670d\u52a1\u3002</p>\n<p>\u4f5c\u4e3a\u4e00\u4e2a\u5177\u6709\u591a\u5e74 websocket \u5f00\u53d1\u7ecf\u9a8c\u7684\u8001\u7a0b\u5e8f\u733f\uff0c\u7ecf\u5386\u4e86 GoEasy \u4f01\u4e1a\u7ea7 websocket \u670d\u52a1\u4ece\u65e0\u5230\u6709\uff0c\u4ece\u5c0f\u5230\u5927\u7684\u8fc7\u7a0b\uff0c\u6b64\u6587\u662f\u6839\u636e\u8fc7\u53bb\u51e0\u5e74\u5728 GoEasy \u5f00\u53d1\u8fc7\u7a0b\u4e2d\u8e29\u8fc7\u7684\u5751\uff0c\u4ee5\u53ca\u4e3a\u4f17\u591a\u5f00\u53d1\u56e2\u961f\u63d0\u4f9b websocket \u670d\u52a1\u3001\u4e0e\u4f17\u591a\u5f00\u53d1\u8005\u4ea4\u6d41\u4e2d\u7684\u603b\u7ed3\u7684\u4e00\u4e9b\u7ecf\u9a8c\u548c\u4f53\u4f1a\u3002</p>\n<p>\u8fd9\u6b21\u4e3b\u8981\u4ece\u642d\u5efa websocket \u670d\u52a1\u7684\u57fa\u672c\u529f\u80fd\u548c\u7279\u6027\u65b9\u9762\u505a\u4e00\u4e9b\u5206\u4eab\uff0c\u4e0b\u6b21\u6709\u673a\u4f1a\u518d\u4ece\u6784\u5efa\u4e00\u4e2a\u9ad8\u53ef\u7528 websocket \u65f6\u8981\u9762\u5bf9\u7684\u9ad8\u5e76\u53d1\uff0c\u6d77\u91cf\u6d88\u606f\uff0c\u96c6\u7fa4\u5bb9\u707e\uff0c\u6a2a\u5411\u6269\u5c55\uff0c\u4ee5\u53ca\u81ea\u52a8\u5316\u8fd0\u7ef4\u7b49\u65b9\u9762\u8fdb\u66f4\u591a\u7684\u5206\u4eab\u3002</p>\n<p>\u4ee5\u4e0b\u51e0\u70b9\u662f\u4e2a\u4eba\u8ba4\u4e3a\u5728\u6784\u5efa websocket \u670d\u52a1\u65f6\u5fc5\u987b\u8981\u8003\u8651\u7684\u4e00\u4e9b\u6280\u672f\u7279\u6027\u4ee5\u53ca\u80fd\u663e\u8457\u63d0\u9ad8\u7528\u6237\u4f53\u9a8c\u7684\u529f\u80fd\uff0c\u4f9b\u5404\u4f4d\u540c\u5b66\u53c2\u8003\uff1a</p>\n<p><strong>1.\u5efa\u7acb\u5fc3\u8df3\u673a\u5236</strong></p>\n<p>\u5fc3\u8df3\u673a\u5236\u51e0\u4e4e\u662f\u6240\u6709\u7f51\u7edc\u7f16\u7a0b\u7684\u7b2c\u4e00\u6b65\uff0c\u7ecf\u5e38\u5bb9\u6613\u88ab\u65b0\u624b\u5ffd\u7565\u3002\u56e0\u4e3a\u5728 websocket \u957f\u8fde\u63a5\u4e2d\uff0c\u5ba2\u6237\u7aef\u548c\u670d\u52a1\u7aef\u5e76\u4e0d\u4f1a\u4e00\u76f4\u901a\u4fe1\uff0c\u5982\u679c\u53cc\u65b9\u957f\u671f\u6ca1\u6709\u6c9f\u901a\u5219\u90fd\u4e0d\u6e05\u695a\u5f7c\u6b64\u5f53\u524d\u72b6\u6001\uff0c\u6240\u4ee5\u9700\u8981\u53d1\u9001\u4e00\u6bb5\u5f88\u5c0f\u7684\u62a5\u6587\u544a\u8bc9\u5bf9\u65b9\u201c\u6211\u8fd8\u6d3b\u7740\u201d\u3002\u53e6\u5916\u8fd8\u6709\u4e24\u4e2a\u76ee\u7684\uff1a</p>\n<p>\u670d\u52a1\u7aef\u68c0\u6d4b\u5230\u67d0\u4e2a\u5ba2\u6237\u7aef\u8fdf\u8fdf\u6ca1\u6709\u5fc3\u8df3\u8fc7\u6765\u53ef\u4ee5\u4e3b\u52a8\u5173\u95ed\u901a\u9053\uff0c\u8ba9\u5b83\u4e0b\u7ebf\uff1b\n\u5ba2\u6237\u7aef\u68c0\u6d4b\u5230\u67d0\u4e2a\u670d\u52a1\u7aef\u8fdf\u8fdf\u6ca1\u6709\u54cd\u5e94\u5fc3\u8df3\u4e5f\u80fd\u91cd\u8fde\u83b7\u53d6\u4e00\u4e2a\u65b0\u7684\u8fde\u63a5\u3002</p>\n<p><strong>2.\u5efa\u7acb\u5177\u6709\u826f\u597d\u517c\u5bb9\u6027\u7684\u5ba2\u6237\u7aef SDK</strong></p>\n<p>\u867d\u8bf4\u73b0\u5728\u4e3b\u6d41\u6d4f\u89c8\u5668\u90fd\u652f\u6301 websocket\uff0c\u4f46\u5728\u7f16\u7801\u4e2d\u8fd8\u662f\u4f1a\u9047\u5230\u6d4f\u89c8\u5668\u517c\u5bb9\u6027\u95ee\u9898\uff0c\u800c\u4e14\u901a\u8fc7 websocket \u901a\u4fe1\u7684\u5ba2\u6237\u7aef\u65e9\u5df2\u4e0d\u4ec5\u9650\u4e8e\u5404\u79cd web \u6d4f\u89c8\u5668\uff0c\u8fd8\u5305\u62ec\u8d8a\u6765\u8d8a\u591a\u7684 APP\uff0c\u5c0f\u7a0b\u5e8f\u3002\u56e0\u6b64\u5c31\u8981\u6c42\u6784\u5efa\u7684 websocket \u670d\u52a1\u5fc5\u987b\u80fd\u591f\u5f88\u53cb\u597d\u7684\u652f\u6301\u5404\u79cd\u5ba2\u6237\u7aef\u3002\u6700\u597d\u7684\u65b9\u5f0f\u5c31\u662f\u6784\u5efa\u4e00\u4e2a\u80fd\u591f\u517c\u5bb9\u6240\u6709\u4e3b\u6d41\u6d4f\u89c8\u5668\u3001\u5c0f\u7a0b\u5e8f\u548c APP\uff0c\u4ee5\u53ca uni-app\u3001vue\u3001react-native \u7b49\u76ee\u524d\u5e38\u89c1\u7684\u5404\u79cd\u524d\u7aef\u6846\u67b6\u7684\u5ba2\u6237\u7aef SDK\uff0c\u8fd9\u6837\u4e0d\u8bba\u516c\u53f8\u7684\u5404\u4e2a\u9879\u76ee\u4f7f\u7528\u4ec0\u4e48\u6837\u7684\u524d\u7aef\u6280\u672f\uff0c\u90fd\u80fd\u591f\u5feb\u901f\u7684\u96c6\u6210 websocket \u670d\u52a1\u3002</p>\n<p><strong>3.\u65ad\u7f51\u81ea\u52a8\u91cd\u8fde\u548c\u6d88\u606f\u8865\u53d1\u673a\u5236</strong></p>\n<p>\u79fb\u52a8\u4e92\u8054\u7f51\u65f6\u4ee3\uff0c\u7ec8\u7aef\u7528\u6237\u6240\u5904\u7684\u7f51\u7edc\u73af\u5883\u591a\u6837\u4e14\u590d\u6742\uff0c\u5982\u7528\u6237\u8fdb\u51fa\u7535\u68af\uff0c\u51fa\u5165\u5730\u4e0b\u5ba4\u6216\u5730\u94c1\u7b49\u7f51\u7edc\u4e0d\u7a33\u5b9a\u7684\u573a\u6240\uff0c\u6216\u5176\u4ed6\u539f\u56e0\u5bfc\u81f4\u7684\u7f51\u7edc\u4e0d\u7a33\u5b9a\u90fd\u662f\u5f88\u5e38\u89c1\u7684\u573a\u666f\u3002\u56e0\u6b64\uff0c\u4e00\u4e2a\u53ef\u9760\u7684 websocket \u670d\u52a1\u5fc5\u987b\u5177\u5907\u5b8c\u5584\u7684\u65ad\u7f51\u81ea\u52a8\u91cd\u8fde\u673a\u5236\u3002\u786e\u4fdd\u65ad\u7f51\u540e\uff0c\u7f51\u7edc\u4e00\u65e6\u6062\u590d\uff0c\u80fd\u7b2c\u4e00\u65f6\u95f4\u81ea\u52a8\u91cd\u65b0\u5efa\u7acb\u957f\u8fde\u63a5\uff0c\u5e76\u4e14\u80fd\u591f\u7acb\u5373\u8865\u53d1\u5728\u7f51\u7edc\u4e0d\u7a33\u5b9a\u671f\u95f4\u53d1\u9001\u7684\u6d88\u606f\u3002</p>\n<p><strong>4.\u79bb\u7ebf\u6d88\u606f</strong></p>\n<p>\u57fa\u7840\u7684 Websocket \u901a\u8baf\u4ece\u6280\u672f\u4e0a\u6765\u8bf4\uff0c\u6d88\u606f\u9001\u8fbe\u7684\u524d\u63d0\u6761\u4ef6\u5c31\u662f\u5efa\u7acb\u8d77\u4e00\u4e2a\u957f\u8fde\u63a5\uff0c\u6ca1\u6709\u5efa\u7acb\u7f51\u7edc\u8fde\u63a5\u5c31\u6765\u8ba8\u8bba\u901a\u8baf\u90a3\u662f\u800d\u6d41\u6c13\u3002\u4f46\u662f\u4ece\u4f7f\u7528\u8005\u7684\u89d2\u5ea6\u4e0a\u6765\u8bf4\uff0c\u968f\u624b\u5173\u95ed\u6d4f\u89c8\u5668\uff0c\u6216\u8005\u5c06\u5c0f\u7a0b\u5e8f\u3001APP \u8fdb\u7a0b\u76f4\u63a5\u6740\u6389\u800c\u5bfc\u81f4\u7f51\u7edc\u8fde\u63a5\u65ad\u5f00\u7684\u60c5\u51b5\u662f\u968f\u65f6\u90fd\u5728\u53d1\u751f\u7684\u3002\u7136\u540e\u6211\u4eec\u4e0b\u610f\u8bc6\u7684\u671f\u5f85\uff0c\u5c31\u662f\u6211\u4e0b\u6b21\u6253\u5f00\u6d4f\u89c8\u5668\u8bbf\u95ee\u7f51\u9875\uff0c\u6216\u8005\u6253\u5f00 APP \u65f6\uff0c\u80fd\u591f\u6536\u5230\u7528\u6237\u79bb\u5f00\u7cfb\u7edf\u671f\u95f4\u7684\u6240\u6709\u4fe1\u606f\u3002\u4ece\u6280\u672f\u4e0a\u8fd9\u662f\u4e00\u4e2a\u8ddf websocket \u6ca1\u6709\u591a\u5927\u5173\u7cfb\u7684\u9700\u6c42\uff0c\u4f46\u5b9e\u9645\u4e0a\u5374\u662f websocket \u670d\u52a1\u4e0d\u53ef\u6216\u7f3a\u7684\u57fa\u672c\u7279\u6027\uff0c\u4e5f\u662f\u4e00\u4e2a\u80fd\u591f\u6781\u5927\u63d0\u5347\u7528\u6237\u4f53\u9a8c\u7684\u529f\u80fd\u3002</p>\n<p><strong>5.\u4e0a\u4e0b\u7ebf\u63d0\u9192\uff0c\u5ba2\u6237\u7aef\u5728\u7ebf\u5217\u8868</strong></p>\n<p>\u638c\u63e1\u5f53\u524d\u7cfb\u7edf\u6709\u54ea\u4e9b\u7528\u6237\u5728\u7ebf\uff0c\u6355\u6349\u7528\u6237\u4e0a\u4e0b\u7ebf\u4e8b\u4ef6\uff0c\u662f\u642d\u5efa\u4e00\u4e2a\u4f01\u4e1a\u7ea7 websocket \u670d\u52a1\uff0c\u5fc5\u4e0d\u53ef\u5c11\u7684\u7279\u6027\uff0c\u5c24\u5176\u662f\u5f00\u53d1 IM \u548c\u6e38\u620f\u7c7b\u4ea7\u54c1\u3002</p>\n<p><strong>6.\u652f\u6301\u5386\u53f2\u6d88\u606f\u67e5\u8be2</strong></p>\n<p>websocket \u670d\u52a1\uff0c\u67d0\u79cd\u610f\u4e49\u4e5f\u662f\u5c5e\u4e8e\u4e00\u4e2a\u6d88\u606f\u7cfb\u7edf\uff0c\u5bf9\u4e8e\u5386\u53f2\u6d88\u606f\u7684\u67e5\u8be2\u9700\u6c42\uff0c\u662f\u65e0\u6cd5\u7ed5\u5f00\u7684\u8bdd\u9898\u3002\u6bd4\u5982 IM \u7cfb\u7edf\u4e2d\u5e38\u89c1\u7684\u5386\u53f2\u6d88\u606f\uff0c\u56e0\u6b64\u5728 websocket \u670d\u52a1\u5185\u90e8\u5b9e\u73b0\u4e00\u4e2a\u9ad8\u901f\uff0c\u53ef\u9760\u7684\u6d88\u606f\u961f\u5217\u673a\u5236\u6765\u652f\u6301 websocket \u670d\u52a1\u5b9e\u73b0\u5386\u53f2\u6d88\u606f\u7684\u67e5\u8be2\u5c31\u662f\u4e00\u4e2a\u5fc5\u987b\u7684\u5de5\u4f5c\u3002</p>\n<p><strong>7.\u6d88\u606f\u7684\u538b\u7f29\u673a\u5236</strong></p>\n<p>\u4e0d\u8bba\u662f\u4e3a\u4e86\u4fdd\u8bc1\u6d88\u606f\u901a\u8baf\u7684\u901f\u5ea6\u548c\u5b9e\u65f6\u6027\uff0c\u8fd8\u662f\u4e3a\u4e86\u8282\u7ea6\u6d41\u91cf\u548c\u5e26\u5bbd\u8d39\u7528\uff0c\u6216\u8005\u662f\u51fa\u4e8e\u63d0\u9ad8\u7f51\u5361\u7684\u4f7f\u7528\u6548\u7387\u548c\u589e\u52a0\u7cfb\u7edf\u7684\u541e\u5410\u91cf\uff0c\u5728\u901a\u8baf\u8fc7\u7a0b\u4e2d\u5bf9\u6d88\u606f\u8fdb\u884c\u5fc5\u8981\u7684\u538b\u7f29\u90fd\u662f\u5fc5\u4e0d\u53ef\u5c11\u7684\u3002</p>\n<p>\u9664\u4e86\u9700\u8981\u8003\u8651\u4ee5\u4e0a\u4e03\u70b9\u4ee5\u5916\uff0c\u7b14\u8005\u8ba4\u4e3a\uff0c\u8fd8\u6709\u51e0\u4e2a\u95ee\u9898\u4e5f\u662f\u5f88\u503c\u5f97\u521d\u5b66\u8005\u79ef\u6781\u5173\u6ce8\u7684\uff1a</p>\n<p><strong>1.\u7f13\u5b58\u548c\u6301\u4e45\u5316</strong></p>\n<p>\u9009\u62e9\u5408\u9002\u7684\u6d88\u606f\u7f13\u5b58\u673a\u5236\uff0c\u662f\u4f01\u4e1a\u7ea7 websocket \u670d\u52a1\u4fdd\u8bc1\u6027\u80fd\u5fc5\u987b\u8981\u8003\u8651\u7684\u95ee\u9898\u3002</p>\n<p><strong>2.\u5f02\u6b65\u8c03\u7528</strong></p>\n<p>\u8981\u652f\u6301\u5927\u91cf\u6d88\u606f\u901a\u8baf\u7684\u9ad8\u6027\u80fd\u7cfb\u7edf\uff0c\u5fc5\u7136\u63a8\u8350\u5f02\u6b65\u8c03\u7528\u3002\u82e5\u8bbe\u8ba1\u4e3a\u540c\u6b65\u8c03\u7528\uff0c\u8c03\u7528\u65b9\u5c31\u9700\u8981\u4e00\u76f4\u7b49\u5f85\u88ab\u8c03\u7528\u65b9\u5b8c\u6210\u3002\u5982\u679c\u4e00\u5c42\u4e00\u5c42\u7684\u540c\u6b65\u8c03\u7528\u4e0b\u53bb\uff0c\u6240\u6709\u7684\u8c03\u7528\u65b9\u9700\u8981\u76f8\u540c\u7684\u7b49\u5f85\u65f6\u95f4\uff0c\u8c03\u7528\u65b9\u7684\u8d44\u6e90\u4f1a\u88ab\u5927\u91cf\u7684\u6d6a\u8d39\u3002\u66f4\u7cdf\u7cd5\u7684\u662f\u4e00\u65e6\u88ab\u8c03\u7528\u65b9\u51fa\u95ee\u9898\uff0c\u5176\u4ed6\u8c03\u7528\u5c31\u4f1a\u51fa\u73b0\u591a\u7c73\u8bfa\u9aa8\u724c\u6548\u5e94\u8ddf\u7740\u51fa\u95ee\u9898\uff0c\u5bfc\u81f4\u6545\u969c\u8513\u5ef6\u3002\u6536\u5230\u8bf7\u6c42\u7acb\u5373\u8fd4\u56de\u7ed3\u679c\uff0c\u7136\u540e\u518d\u5f02\u6b65\u6267\u884c\uff0c\u4e0d\u4ec5\u53ef\u4ee5\u589e\u52a0\u7cfb\u7edf\u7684\u541e\u5410\u91cf\uff0c\u6700\u5927\u7684\u597d\u5904\u662f\u8ba9\u670d\u52a1\u4e4b\u95f4\u7684\u89e3\u8026\u66f4\u4e3a\u5f7b\u5e95\u3002</p>\n<p><strong>3.\u72ec\u7acb\u4e8e\u4e1a\u52a1\u548c\u6807\u51c6\u5316</strong></p>\n<p>\u5c3d\u7ba1\u5728\u4e00\u4e2a web \u9879\u76ee\u4e2d\u53ef\u4ee5\u540c\u65f6\u5b58\u5728\u5e38\u89c4 http \u670d\u52a1\u548c websocket \u670d\u52a1\uff0c\u5c24\u5176\u5bf9\u6027\u80fd\u8981\u6c42\u4e0d\u9ad8\u7684\u5355\u5e94\u7528 web \u7cfb\u7edf\uff0c\u8fd9\u79cd\u65b9\u5f0f\u66f4\u7b80\u5355\uff0c\u66f4\u4fbf\u4e8e\u7ef4\u62a4\u3002\u4f46\u5bf9\u4e8e\u6027\u80fd\u548c\u53ef\u7528\u6027\u9ad8\u7684\u4f01\u4e1a\u7ea7\u7cfb\u7edf\u6216\u8005\u4e92\u8054\u7f51\u5e73\u53f0\uff0c\u66f4\u597d\u7684\u65b9\u5f0f\uff0c\u662f\u5c06 websocket \u670d\u52a1\u4f5c\u4e3a\u4e00\u4e2a\u5355\u72ec\u7684\u5fae\u670d\u52a1\u6765\u8fdb\u884c\u8bbe\u8ba1\uff0c\u907f\u514d\u548c\u5e38\u89c4\u7684 http \u670d\u52a1\u62a2\u5360\u8d44\u6e90\uff0c\u5bfc\u81f4\u7cfb\u7edf\u6027\u80fd\u4e0d\u53ef\u63a7\uff0c\u540c\u65f6\u4e5f\u66f4\u4fbf\u4e8e\u6a2a\u5411\u6269\u5c55\u3002</p>\n<p>\u4e00\u4e2a\u8bbe\u8ba1\u826f\u597d\u7684\u4f01\u4e1a\u7ea7 websocket \u670d\u52a1\u5e94\u8be5\u662f\u4e00\u4e2a\u72ec\u7acb\u4e8e\u4e1a\u52a1\u7cfb\u7edf\u3001\u6807\u51c6\u5316\u7684\u5355\u72ec\u5b58\u5728\u7684\u6280\u672f\u6027\u5fae\u670d\u52a1\uff0c\u80fd\u591f\u4f5c\u4e3a\u516c\u53f8\u57fa\u7840\u67b6\u6784\u7684\u4e00\u90e8\u5206\u4e3a\u516c\u53f8\u7684\u6240\u6709\u9879\u76ee\u63d0\u4f9b\u901a\u8baf\u670d\u52a1\u3002</p>\n<p><strong>4.\u5e42\u7b49\u6027\u548c\u91cd\u590d\u6d88\u606f\u7684\u8fc7\u6ee4</strong></p>\n<p>\u6240\u8c13\u5e42\u7b49\u6027\uff0c\u5c31\u662f\u4e00\u6b21\u548c\u591a\u6b21\u8bf7\u6c42\u4e00\u4e2a\u63a5\u53e3\u90fd\u5e94\u8be5\u5177\u6709\u540c\u6837\u7684\u540e\u679c\u3002\u4e3a\u4ec0\u4e48\u9700\u8981\uff1f\u5bf9\u6bcf\u4e2a\u63a5\u53e3\u7684\u8c03\u7528\u90fd\u4f1a\u6709\u4e09\u79cd\u53ef\u80fd\u7684\u7ed3\u679c\uff1a\u6210\u529f\uff0c\u5931\u8d25\u548c\u8d85\u65f6\u3002\u5bf9\u6700\u540e\u4e00\u79cd\u7684\u539f\u56e0\u5f88\u591a\u53ef\u80fd\u662f\u7f51\u7edc\u4e22\u5305\uff0c\u53ef\u80fd\u8bf7\u6c42\u6ca1\u6709\u5230\u8fbe\uff0c\u4e5f\u6709\u53ef\u80fd\u8fd4\u56de\u6ca1\u6709\u6536\u5230\u3002\u4e8e\u662f\u5728\u5bf9\u63a5\u53e3\u7684\u8c03\u7528\u65f6\u5f80\u5f80\u90fd\u4f1a\u6709\u91cd\u8bd5\u673a\u5236\uff0c\u4f46\u91cd\u8bd5\u673a\u5236\u5f88\u5bb9\u6613\u5bfc\u81f4\u6d88\u606f\u7684\u91cd\u590d\u53d1\u9001\uff0c\u4ece\u7528\u6237\u5c42\u9762\u8fd9\u5f80\u5f80\u662f\u4e0d\u53ef\u63a5\u53d7\u7684\uff0c\u56e0\u6b64\u5728\u63a5\u53e3\u7684\u8bbe\u8ba1\u65f6\uff0c\u6211\u4eec\u5c31\u9700\u8981\u8003\u8651\u63a5\u53e3\u7684\u5e42\u7b49\u6027\uff0c\u786e\u4fdd\u540c\u4e00\u6761\u6d88\u606f\u53d1\u9001\u4e00\u6b21\u548c\u5341\u6b21\u90fd\u4e0d\u56de\u5bfc\u81f4\u6d88\u606f\u7684\u91cd\u590d\u5230\u8fbe\u3002</p>\n<p><strong>5.\u652f\u6301 QoS \u670d\u52a1\u8d28\u91cf\u5206\u7ea7</strong></p>\n<p>\u5176\u5b9e\u5bf9\u4e8e\u4e0a\u4e00\u70b9\u6d88\u606f\u91cd\u590d\u7684\u95ee\u9898\uff0c\u884c\u4e1a\u5df2\u7ecf\u6709\u4e86\u89e3\u51b3\u65b9\u6848\u548c\u6807\u51c6\u89c4\u8303\uff0c\u5bf9\u4e8e\u6d88\u606f\u5230\u8fbe\u7387\u548c\u91cd\u590d\uff0c\u5e38\u7528\u7684\u624b\u6bb5\u5c31\u662f\u901a\u8fc7\u6d88\u606f\u786e\u8ba4\u7684\u65b9\u5f0f\u6765\u786e\u4fdd\u6d88\u606f\u5230\u8fbe\uff0c\u8981\u6c42\u8d8a\u9ad8\uff0c\u610f\u5473\u7740\u786e\u8ba4\u673a\u5236\u8d8a\u590d\u6742\uff0c\u6210\u672c\u8d8a\u9ad8\u3002\u4e3a\u4e86\u5728\u6210\u672c\u548c\u5230\u8fbe\u7387\u4e4b\u95f4\u6709\u5f88\u597d\u7684\u5e73\u8861\uff0c\u901a\u5e38\u5bf9\u6d88\u606f\u7cfb\u7edf\u7684\u670d\u52a1\u8d28\u91cf\uff08 QoS \uff09\u5206\u4e3a\u4ee5\u4e0b\u4e09\u4e2a\u7ea7\u522b \uff1a</p>\n<p>QoS 0(At most once)\uff1a\u201c\u6700\u591a\u53d1\u4e00\u6b21\u201d\uff0c\u610f\u5473\u7740\u53d1\u9001\u5c31\u53ef\u4ee5\u4e86\uff0c\u4e0d\u9700\u8981\u786e\u8ba4\u673a\u5236\uff0c\u53d1\u9001\u4e86\u5373\u53ef\uff0c\u9002\u7528\u4e8e\u8981\u6c42\u4e0d\u9ad8\u7684\u573a\u666f\uff0c\u53ef\u4ee5\u63a5\u53d7\u4e00\u5b9a\u7684\u4e0d\u5230\u8fbe\u7387\uff0c\u6210\u672c\u6700\u4f4e\u3002</p>\n<p>QoS 1(At least once)\uff1a\u201c\u81f3\u5c11\u53d1\u4e00\u6b21\u201d\uff0c\u610f\u5473\u7740\u53d1\u9001\u65b9\u5fc5\u987b\u660e\u786e\u6536\u5230\u63a5\u6536\u65b9\u7684\u786e\u8ba4\u4fe1\u53f7\uff0c\u5426\u5219\u5c31\u4f1a\u53cd\u590d\u53d1\uff0c\u6bcf\u6761\u6d88\u606f\u81f3\u5c11\u9700\u8981\u4e24\u6b21\u901a\u4fe1\u6765\u786e\u8ba4\u5230\u8fbe\uff0c\u53ef\u4ee5\u63a5\u53d7\u4e00\u4e9b\u6d88\u606f\u88ab\u91cd\u53d1\uff0c\u4f46\u6210\u672c\u4e0d\u9ad8\u3002</p>\n<p>QoS 2(Exactly once)\uff1a\u201c\u786e\u4fdd\u53ea\u53d1\u4e00\u6b21\u201d\uff0c\u610f\u5473\u7740\u6bcf\u6761\u6d88\u606f\u53ea\u80fd\u5230\u8fbe\u4e00\u6b21\uff0c\u4e14\u4e0d\u5141\u8bb8\u91cd\u590d\u5230\u8fbe\uff0c\u4e3a\u4e86\u8fbe\u5230\u8fd9\u4e2a\u76ee\u6807\u5c31\u9700\u8981\u53cc\u65b9\u81f3\u5c11\u901a\u8baf\u4e09\u6b21\uff0c\u6210\u672c\u6700\u9ad8\u3002</p>\n<p>\u4e00\u4e2a\u5b8c\u5584\u7684 websocket \u670d\u52a1\u9762\u5bf9\u4e0d\u540c\u7684\u5e94\u7528\u573a\u666f\uff0c\u5e94\u8be5\u80fd\u591f\u652f\u6301\u9009\u62e9\u4e0d\u540c\u7b49\u7ea7\u7684 QoS\uff0c\u5728\u6210\u672c\u548c\u670d\u52a1\u8d28\u91cf\u4e4b\u95f4\u53d6\u5f97\u5e73\u8861\u3002</p>\n<p><strong>\u6700\u540e</strong></p>\n<p>\u867d\u7136 websocket \u5df2\u7ecf\u5e7f\u6cdb\u7684\u5e94\u7528\u4e8e\u5404\u79cd\u7cfb\u7edf\u548c\u5e73\u53f0\uff0c\u4f46\u5982\u679c\u8981\u642d\u5efa\u4e00\u4e2a\u6ee1\u8db3\u4f01\u4e1a\u7ea7\u6216\u8005\u5927\u578b\u4e92\u8054\u7f51\u5e73\u53f0\u7684\u53ef\u9760\u3001\u5b89\u5168\u7a33\u5b9a\u7684 websocket \u670d\u52a1\uff0c\u5bf9\u4e8e\u6ca1\u6709\u7ecf\u9a8c\u7684\u540c\u5b66\uff0c\u5728\u5177\u4f53\u7684\u6280\u672f\u5b9e\u8df5\u8fc7\u7a0b\u4f9d\u7136\u662f\u6709\u4e0d\u5c11\u7684\u5751\u8981\u8e29\u3002</p>\n<p>\u5bf9 websocket \u670d\u52a1\u6709\u8f83\u9ad8\u8981\u6c42\uff0c\u9009\u62e9\u6210\u719f\u53ef\u9760\u7684\u7b2c\u4e09\u65b9 websocket \u670d\u52a1\u5176\u5b9e\u4e5f\u662f\u4e00\u4e2a\u6210\u672c\u66f4\u4f4e\u548c\u9ad8\u6548\u7684\u9009\u62e9\u3002GoEasy \u4f5c\u4e3a\u56fd\u5185\u9886\u5148\u7684\u7b2c\u4e09\u65b9 websocket \u6d88\u606f\u5e73\u53f0\uff0c\u5df2\u7ecf\u7a33\u5b9a\u8fd0\u884c\u4e86 5 \u5e74\u65f6\u95f4\uff0c\u652f\u6301\u5343\u4e07\u7ea7\u6d88\u606f\u5e76\u53d1\uff0c\u9664\u4e86\u517c\u5bb9\u6240\u6709\u5e38\u89c1\u7684\u6d4f\u89c8\u5668\u4ee5\u5916\uff0c\u540c\u65f6\u4e5f\u517c\u5bb9 uni-app\uff0c\u5404\u79cd\u5c0f\u7a0b\u5e8f\uff0c\u4ee5\u53ca vue\u3001react-native \u7b49\u5e38\u89c1\u7684\u524d\u7aef\u6846\u67b6\u3002</p>\n<p>\u5e0c\u671b\u672c\u6587\u80fd\u4e3a\u521d\u6b21\u642d\u5efa websocket \u670d\u52a1\u7684\u540c\u5b66\u5728\u601d\u8def\u4e0a\u6709\u6240\u5e2e\u52a9\u548c\u53c2\u8003\uff0c\u4e5f\u6b22\u8fce\u5404\u4f4d\u524d\u8f88\u591a\u591a\u6279\u8bc4\u6307\u6b63\uff0c\u540c\u65f6\u4e5f\u5e0c\u671b\u672a\u6765\u6709\u673a\u4f1a\u5c31\u66f4\u591a\u7684\u6280\u672f\u4e0e\u5927\u5bb6\u8fdb\u884c\u4ea4\u6d41\u3002</p>\n<p>GoEasy \u5b98\u7f51\uff1a <a href=\"https://www.goeasy.io/\" rel=\"nofollow\">https://www.goeasy.io/</a></p>\n"
    }, 
    {
      "author": {
        "url": "https://www.v2ex.com/member/mengdodo", 
        "name": "mengdodo", 
        "avatar": "https://cdn.v2ex.com/avatar/2d54/6428/194136_large.png?m=1577710510"
      }, 
      "url": "https://www.v2ex.com/t/630766", 
      "date_modified": "2019-12-20T02:53:57+00:00", 
      "content_html": "<p>websocket \u804a\u5929\u5ba4\u4e2d\u79c1\u804a\u529f\u80fd\uff0c\u5e94\u8be5\u5c31\u662f\u4e24\u4e2a\u7528\u6237\u7684 client_id \u4e4b\u95f4\u901a\u4fe1\u5427\u3002<br/>\n\u90a3\u9891\u9053\u7fa4\u804a\u529f\u80fd\u5462\uff1f<br/>\n\u7ffb\u4e86\u4e0b\u522b\u4eba\u5199\u7684 demo\uff0c\u90fd\u662f foreach \u904d\u5386\u8be5\u9891\u9053\u7684\u6240\u6709 client_id \u7136\u540e\u9010\u4e2a\u63a8\u9001\uff0c\u611f\u89c9\u597d low\uff0c\u90a3\u5982\u679c\u767e\u4eba\u7fa4\uff0c\u5343\u4eba\u7fa4\uff0c\u4e07\u4eba\u7fa4\uff0c\u90a3\u670d\u52a1\u5668\u5c82\u4e0d\u662f\u70b8\u9505\u4e86,\u9ebb\u70e6\u5927\u4f6c\u6307\u70b9\u4e0b\u3002</p>\n<pre><code>//demo \u8fdb\u7a0b\u542f\u52a8\u5411\u6240\u6709\u5ba2\u6237\u7aef\u8fde\u63a5\u53d1\u9001\u6570\u636e\nforeach ($room_users as $key =&gt; $clientId){\n\n   if ($currentSessionId != $clientId){\n         $this-&gt;send($clientId, $msg);\n   }else{\n         $this-&gt;send($clientId, $msg_my);\n   }\n}\n</code></pre>\n", 
      "date_published": "2019-12-20T02:51:38+00:00", 
      "title": "\u6700\u8fd1\u5728\u770b websocket \u7684\u804a\u5929\u5ba4\u529f\u80fd\uff0c\u6709\u4e2a\u5c0f\u7591\u95ee", 
      "id": "https://www.v2ex.com/t/630766"
    }
  ]
}