{"id":1236,"date":"2023-10-25T16:49:57","date_gmt":"2023-10-25T08:49:57","guid":{"rendered":"https:\/\/log.tanxiaodian.com\/?p=1236"},"modified":"2023-10-25T16:49:57","modified_gmt":"2023-10-25T08:49:57","slug":"%e6%9c%8d%e5%8a%a1%e7%ab%af%e6%8e%a8%e9%80%81%e5%9f%ba%e4%ba%8enodejs%e5%ae%9e%e7%8e%b0text-event-stream%e7%ae%80%e5%8d%95%e5%ba%94%e7%94%a8%e6%a1%88%e4%be%8b%ef%bc%8csse","status":"publish","type":"post","link":"https:\/\/log.tanxiaodian.com\/?p=1236","title":{"rendered":"\u670d\u52a1\u7aef\u63a8\u9001:\u57fa\u4e8enodejs\u5b9e\u73b0text\/event-stream\u7b80\u5355\u5e94\u7528\u6848\u4f8b\uff0cSSE"},"content":{"rendered":"\n<p>\u8f6c\u81ea<\/p>\n\n\n\n<p><a href=\"https:\/\/blog.csdn.net\/ta_huang\/article\/details\/131071617\">https:\/\/blog.csdn.net\/ta_huang\/article\/details\/131071617<\/a><\/p>\n\n\n\n<p><\/p>\n\n\n\n<p>text\/event-stream<br>\u662f\u4e00\u79cd\u7528\u4e8e\u670d\u52a1\u5668\u5411\u5ba2\u6237\u7aef\u63a8\u9001\u4e8b\u4ef6\u7684\u5a92\u4f53\u7c7b\u578b\uff08Media Type\uff09\u3002\u5b83\u662f\u57fa\u4e8e HTTP \u534f\u8bae\u7684\u4e00\u79cd\u6d41\u5f0f\u4f20\u8f93\u6280\u672f\uff0c\u4e5f\u88ab\u79f0\u4e3a Server-Sent Events\uff08SSE\uff09<\/p>\n\n\n\n<p>\u683c\u5f0f\uff1atext\/event-stream \u4f7f\u7528\u7eaf\u6587\u672c\u7684\u683c\u5f0f\uff0c\u57fa\u4e8e\u6362\u884c\u7b26\u5206\u9694\u6bcf\u4e2a\u4e8b \u4ef6\u3002\u6bcf\u4e2a\u4e8b\u4ef6\u7531\u591a\u4e2a\u5b57\u6bb5\u7ec4\u6210\uff0c\u5305\u62ec\u4e8b\u4ef6\u7c7b\u578b\u3001\u6570\u636e\u7b49\u3002\u5e38\u89c1\u5b57\u6bb5\u6709 event\u3001data\u3001id\u3001retry \u7b49\uff08\u5305\u542b\u56db\u4e2a\u5b57\u6bb5\uff1aevent\u3001data\u3001id\u548cretry\u3002event\u8868\u793a\u4e8b\u4ef6\u7c7b\u578b\uff0cdata\u8868\u793a\u6d88\u606f\u5185\u5bb9\uff0cid\u7528\u4e8e\u8bbe\u7f6e\u5ba2\u6237\u7aefEventSource\u5bf9\u8c61\u7684\u201clast event ID string\u201d\u5185\u90e8\u5c5e\u6027\uff0cretry\u6307\u5b9a\u4e86\u91cd\u65b0\u8fde\u63a5\u7684\u65f6\u95f4\uff09\u3002<br>\u4e8b\u4ef6\u6d41\uff1a\u670d\u52a1\u5668\u901a\u8fc7\u6301\u4e45\u8fde\u63a5\uff08\u957f\u8f6e\u8be2\u6216HTTP\/2\u6d41\uff09\u5c06\u4e8b\u4ef6\u6d41\u5f0f\u4f20\u8f93\u7ed9\u5ba2\u6237\u7aef\u3002\u5ba2\u6237\u7aef\u901a\u8fc7\u76d1\u542c onmessage \u4e8b\u4ef6\u6765\u63a5\u6536\u5e76\u5904\u7406\u4ece\u670d\u52a1\u5668\u53d1\u9001\u7684\u4e8b\u4ef6\u3002<br>\u670d\u52a1\u5668\u63a8\u9001\uff1a\u670d\u52a1\u5668\u53ef\u4ee5\u5728\u4efb\u4f55\u65f6\u95f4\u70b9\u5411\u5ba2\u6237\u7aef\u63a8\u9001\u4e8b\u4ef6\uff0c\u65e0\u9700\u5ba2\u6237\u7aef\u53d1\u8d77\u8bf7\u6c42\u3002\u8fd9\u4f7f\u5f97\u5b9e\u65f6\u66f4\u65b0\u3001\u901a\u77e5\u548c\u63a8\u9001\u7b49\u5e94\u7528\u573a\u666f\u53d8\u5f97\u53ef\u884c\uff0c\u4f8b\u5982\u804a\u5929\u5e94\u7528\u3001\u5b9e\u65f6\u80a1\u7968\u62a5\u4ef7\u3001\u5373\u65f6\u901a\u77e5\u7b49\u3002<br>\u5904\u7406\u4e22\u5931\u8fde\u63a5\uff1a<br>\u5982\u679c\u5ba2\u6237\u7aef\u4e0e\u670d\u52a1\u5668\u4e4b\u95f4\u7684\u8fde\u63a5\u4e2d\u65ad\uff0c\u5ba2\u6237\u7aef\u53ef\u4ee5\u5c1d\u8bd5\u91cd\u65b0\u8fde\u63a5\u4ee5\u7ee7\u7eed\u63a5\u6536\u4e8b\u4ef6\u3002<br>\u5ba2\u6237\u7aef\u53ef\u4ee5\u4f7f\u7528 Last-Event-ID \u8bf7\u6c42\u5934\u5b57\u6bb5\u6765\u6307\u5b9a\u4ece\u7279\u5b9a\u4e8b\u4ef6 ID \u5f00\u59cb\u63a5\u6536\u4e8b\u4ef6\uff0c\u4ee5\u4fbf\u5904\u7406\u8fde\u63a5\u65ad\u5f00\u540e\u7684\u4e8b\u4ef6\u4e0d\u4e22\u5931\u3002<br>\u4f7f\u7528 text\/event-stream\uff0c\u670d\u52a1\u5668\u53ef\u4ee5\u5b9e\u73b0\u4e0e\u5ba2\u6237\u7aef\u7684\u5b9e\u65f6\u53cc\u5411\u901a\u4fe1\uff0c\u901a\u8fc7\u63a8\u9001\u4e8b\u4ef6\u6765\u4f20\u9012\u5b9e\u65f6\u6570\u636e\u548c\u72b6\u6001\u53d8\u5316\u3002\u5b83\u4e0e\u5176\u4ed6\u5b9e\u65f6\u901a\u4fe1\u6280\u672f\uff08\u5982 WebSocket\uff09\u76f8\u6bd4\uff0c\u66f4\u9002\u5408\u4e8e\u5355\u5411\u7684\u670d\u52a1\u5668\u5411\u5ba2\u6237\u7aef\u7684\u901a\u4fe1\u573a\u666f\uff0c\u4e0d\u652f\u6301\u5ba2\u6237\u7aef\u5411\u670d\u52a1\u5668\u53d1\u9001\u6d88\u606f\u3002\u5b83\u63d0\u4f9b\u4e86\u4e00\u79cd\u7b80\u5355\u7684\u65b9\u5f0f\u6765\u5b9e\u73b0\u670d\u52a1\u5668\u63a8\u9001\u7684\u529f\u80fd\uff0c\u4e14\u5728\u6d4f\u89c8\u5668\u7aef\u7684\u517c\u5bb9\u6027\u8f83\u597d\u3002<\/p>\n\n\n\n<p> \u670d\u52a1\u5668\u7aef<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const http = require('http');\r\nconst yun = express();\r\nconst eventServer = http.createServer((req, res) => {\r\n    res.writeHead(200, {\r\n        'Content-Type': 'text\/event-stream',\r\n        'Cache-Control': 'no-cache',\r\n        'Connection': 'keep-alive',\r\n        'Access-Control-Allow-Origin': \"*\",\r\n        'Access-Control-Allow-Headers': 'Content-Type,Content-Length,Authorization,Accept,X-Requested-With',\r\n        'Access-Control-Allow-Methods': 'PUT,POST,GET,DELETE,OPTIONS'\r\n    });\r\n    setInterval(() => {\r\n    \t\/\/ \u4e8b\u4ef6\u8981\u7528\u4e24\u4e2a\\n\u7ed3\u675f\r\n        res.write('data: The server time is: ' + new Date() + '\\n\\n');\r\n    }, 1000);\r\n    req.connection.addListener('close', () => {\r\n        console.log('SSE connection closed!');\r\n    }, false);\r\n}).listen(4001);\r\n<\/code><\/pre>\n\n\n\n<p>\u524d\u7aef<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>mounted() {\r\n   const evtSource = new EventSource(\"http:\/\/localhost:4001\/\");\r\n      evtSource.onmessage = function(event) {\r\n         console.log('event', event)\r\n          const serverTime = document.getElementById('serverTime');\r\n          serverTime.innerHTML = event.data;\r\n     };\r\n }\r\n<\/code><\/pre>\n\n\n\n<p><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u8f6c\u81ea https:\/\/blog.csdn.net\/&#8230;<\/p>\n<div class=\"more-link-wrapper\"><a class=\"more-link\" href=\"https:\/\/log.tanxiaodian.com\/?p=1236\">Continue reading<span class=\"screen-reader-text\">\u670d\u52a1\u7aef\u63a8\u9001:\u57fa\u4e8enodejs\u5b9e\u73b0text\/event-stream\u7b80\u5355\u5e94\u7528\u6848\u4f8b\uff0cSSE<\/span><\/a><\/div>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":[],"categories":[218],"tags":[219,220],"_links":{"self":[{"href":"https:\/\/log.tanxiaodian.com\/index.php?rest_route=\/wp\/v2\/posts\/1236"}],"collection":[{"href":"https:\/\/log.tanxiaodian.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/log.tanxiaodian.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/log.tanxiaodian.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/log.tanxiaodian.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=1236"}],"version-history":[{"count":1,"href":"https:\/\/log.tanxiaodian.com\/index.php?rest_route=\/wp\/v2\/posts\/1236\/revisions"}],"predecessor-version":[{"id":1237,"href":"https:\/\/log.tanxiaodian.com\/index.php?rest_route=\/wp\/v2\/posts\/1236\/revisions\/1237"}],"wp:attachment":[{"href":"https:\/\/log.tanxiaodian.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=1236"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/log.tanxiaodian.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=1236"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/log.tanxiaodian.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=1236"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}