av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

html5 - EventSource報(bào)錯(cuò)

瀏覽:117日期:2023-09-08 10:09:00

問(wèn)題描述

錯(cuò)誤

Error: Can’t set headers after they are sent.

at ServerResponse.OutgoingMessage.setHeader (_http_outgoing.js:357:11)at ServerResponse.header (D:nodejavascript-demonode_modulesexpresslibresponse.js:730:10)at ServerResponse.send (D:nodejavascript-demonode_modulesexpresslibresponse.js:170:12)at Timeout.setInterval [as _onTimeout] (D:nodejavascript-demorouteseventsourceeventsource.js:8:8)at ontimeout (timers.js:384:18)at tryOnTimeout (timers.js:244:5)at Timer.listOnTimeout (timers.js:214:5) Program node --debug ./bin/www exited with code 1

const express = require(’express’);const router = express.Router();router.get(’/connect’,function(req,resp,next){ resp.append(’Content-Type’,’text/event-stream’); console.log(req.method); setInterval((data)=>{resp.send(’hello!’); },1000,’hello’);});router.get(’/html’,(req,resp,next)=>{ resp.render(’./eventsource/msgsend_recevie.html’);});module.exports=router;

<!DOCTYPE html><html lang='en'><head> <title>EventSource消息發(fā)送</title> <style type='text/css'>*{ margin:0 auto; padding:0;}p{ width:440px; height:450px; border:2px solid; margin-top:100px;}</style></head><body> <p><textarea rows='30' cols='60'></textarea> </p> <script>//使用eventsource發(fā)送信息var eventSource = new EventSource(’/msg_send/connect’);eventSource.onmessage=function(e){ var tx=document.getElementsByTagName(’textarea’)[0]; tx.value=e.data;}; </script></body> </html>

問(wèn)題解答

回答1:

問(wèn)題已解決,需要給發(fā)送的數(shù)據(jù)加上'data:'前綴,'nn'后綴,即'data'+msg+'nn'服務(wù)端代碼修改如下:

const express = require(’express’);const router = express.Router();router.get(’/connect’,function(req,resp,next){ resp.writeHead(200,{'Content-Type':'text/event-stream','Cache-Control':'no-cache','Connection':'keep-alive' }); setInterval(function(){ resp.write('data:'+Date.now()+'nn'); },1000);});router.get(’/html’,(req,resp,next)=>{ resp.render(’./eventsource/msgsend_recevie.html’);});module.exports=router;回答2:?jiǎn)栴}

在express的response已經(jīng)send后,response不允許再進(jìn)行header等一系列的操作,setintval是一個(gè)定時(shí)器,你的邏輯方式?jīng)]有正確。你的setintval第一次已經(jīng)把響應(yīng)推送出去了,那么后面這個(gè)響應(yīng)已經(jīng)不能繼續(xù)操作了,由于http是單向非雙向的,所以第二次是無(wú)效的操作

解決方案

如果你希望客戶(hù)端能夠接受服務(wù)端得事件推送的話(huà),我推薦使用socketio,或者使用ajax輪訓(xùn)去處理。

標(biāo)簽: Html5
相關(guān)文章:
主站蜘蛛池模板: 欧美日韩久久 | 一区二区三区视频在线 | 亚洲精品乱码久久久久久按摩观 | 激情在线视频网站 | 精品欧美一区二区三区免费观看 | 91国内精品 | 九九看片 | 97精品国产97久久久久久免费 | 欧美日韩一区在线播放 | 中文字幕av高清 | 日韩在线视频免费观看 | 欧美在线一区二区三区 | 国产视频一区在线 | 羞羞视频免费在线 | 久久这里有精品 | 欧美黄色一区 | 男女视频在线观看网站 | 欧美一区二区三区的 | 久久99精品久久久久久国产越南 | 国产美女在线观看 | 欧美一区永久视频免费观看 | 91传媒在线观看 | 欧美在线视频网 | 亚洲视频不卡 | 香蕉婷婷 | 一区二区三区精品视频 | 91亚洲精品久久久电影 | 成人欧美一区二区三区白人 | 天天色综 | 精品国产一区二区三区久久 | 欧美亚洲另类在线 | 爱爱视频在线观看 | a在线观看| 国产欧美一区二区三区在线看 | 欧美精品国产精品 | 99久久国产综合精品麻豆 | 国产成人免费在线观看 | 欧美日本久久 | 日本精品视频在线 | 中国一级特黄真人毛片 | 日韩视频观看 |