pbootcms网站模板|日韩1区2区|织梦模板||网站源码|日韩1区2区|jquery建站特效-html5模板网

淺談HTML5 服務器推送事件(Server-sent Events)

這篇文章主要介紹了淺談HTML5 服務器推送事件(Server-sent Events) ,具有一定的參考價值,有興趣的可以了解一下

服務器推送事件(Server-sent Events)是基于WebSocket 協議的一種服務器向客戶端發送事件&數據的單向通訊。目前所有主流瀏覽器均支持服務器發送事件,當然除了 Internet Explorer 。2333...

WebSocket 協議是繼HTTP協議后又一服務器客戶端通訊協議,不同于HTTP單純的客戶端請求服務器響應單向通訊模式的是它支持了服務端客戶端的雙向通訊。

Server-sent Events 的使用

Server-sent Events(以下簡稱SSE)作為服務器=>客戶端通訊方式那必然客戶端要有相應的服務地址和響應方法,服務端要有相應的數據發送方法;廢話不多說,上代碼!

客戶端JS代碼

 H5頁面需添加如下JS代碼:

     <script>
         if (typeof (EventSource) !== "undefined") {
             //推送服務接口地址
             var eventSource = new EventSource("http://localhost:2242/webservice/ServerSent/SentNews");
             //當通往服務器的連接被打開
             eventSource.onopen = function () {
                 console.log("連接打開...");
             }
              //當錯誤發生
              eventSource.onerror= function (e) {
                  console.log(e);
              };
              //當接收到消息,此事件為默認事件
              eventSource.onmessage = function (event) {
                  console.log("onmessage...");
               eventSource.close()//關閉SSE鏈接
              };
              //服務器推送sentMessage事件
              eventSource.addEventListener('sentMessage', function (event) { 
                  var data = eval('('+event.data+')');//服務器端推送的數據,eval裝換Json對象
                  var origin = event.origin;//服務器 URL 的域名部分,即協議、域名和端口,表示消息的來源。
                  var lastEventId = event.lastEventId;////數據的編號,由服務器端發送。如果沒有編號,這個屬性為空。
                  //此處根據需求編寫業務邏輯
                  console.log(data);              }, false);
          } else {
              //瀏覽器不支持server-sent events 所有主流瀏覽器均支持服務器發送事件,除了 Internet Explorer。
              document.getElementById("result").innerHTML = "Sorry, your browser does not support server-sent events...";
          }
      </script>

服務端

服務端應當返回怎樣的數據格式?應當以什么樣的響應給客戶端呢?先來個.Net 的樣例

    /// <summary>
        /// 推送消息
        /// </summary>
        /// <returns></returns>
        [HttpGet]
        public HttpResponseMessage SentNews()
        {
            HttpResponseMessage response = Request.CreateResponse(HttpStatusCode.OK);
            try
            {
                //response.Headers.Add("Access-Control-Allow-Origin", "*");//如需要跨域可配置
                string data_str = “推送至客戶端的數據”;//當然可以是json字符串格式
                string even = "", data = "";
                if (!string.IsNullOrWhiteSpace(data_str))
                {
                    even = "event:sentMessage\n";
                    data = "data:" + data_str + "\n\n";
                }
                string retry = "retry:" + 1000 + "\n";//連接斷開后重連時間(毫秒),其實可以理解為輪詢時間 2333...
                byte[] array = Encoding.UTF8.GetBytes(even + data + retry);
                Stream stream_result = new MemoryStream(array);
                response.Content = new StreamContent(stream_result);
                response.Content.Headers.ContentType = new MediaTypeHeaderValue("text/event-stream");//此處一定要配置
                response.Headers.CacheControl = new CacheControlHeaderValue();
                response.Headers.CacheControl.NoCache = false;
            }
            catch (Exception ex)
            {
                LogHelper.WriteWebLog(ex);
            }
            return response;
        }

看完以上代碼我想你應該有個大概了,響應的方式還是HTTPResponse響應,但總是有點小小的要求的:

響應報頭"Content-Type" 要設置為 "text/event-stream"

響應的數據格式也應該注意到了上述代碼中的"data:"、"event:"和"retry:"這些標記:

1.event:表示該行用來聲明事件的類型。瀏覽器在收到數據時,會產生對應類型的事件。

2.data:表示該行包含的是數據。以 data 開頭的行可以出現多次。所有這些行都是該事件的數據。

3.retry:表示該行用來聲明瀏覽器在連接斷開之后進行再次連接之前的等待時間。

4.id:表示該行用來聲明事件的標識符(即數據的編號),不常用。

以上就是Server-sent Events的簡單應用,實現效果我就不再展示了,有興趣可以親自操作實現效果!

【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。

相關文檔推薦

這篇文章主要介紹了有關HTML5頁面在iPhoneX適配問題,需要的朋友可以參考下
本篇文章主要介紹了html5中canvas圖表實現柱狀圖的示例,本文使用canvas來實現一個圖表,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
Adobe公司出品的多媒體處理軟件產品線較多,涵蓋了音視頻編輯、圖像處理、平面設計、影視后期等領域。這篇文章主要介紹了Adobe Html5 Extension開發初體驗圖文教程,非常不錯,需要的朋
這篇文章主要介紹了基于HTML5的WebGL經典3D虛擬機房漫游動畫,需要的朋友可以參考下
這篇文章主要介紹了html5實現移動端適配完美寫法,需要的朋友可以參考下
本篇文章主要介紹了HTML5響應式(自適應)網頁設計的實現,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
主站蜘蛛池模板: 污水提升器,污水提升泵,地下室排水,增压泵,雨水泵,智能供排水控制器-上海智流泵业有限公司 | 聚丙烯酰胺_阴离子_阳离子「用量少」巩义亿腾厂家直销,售后无忧 聚合甘油__盐城市飞龙油脂有限公司 | 精密五金冲压件_深圳五金冲压厂_钣金加工厂_五金模具加工-诚瑞丰科技股份有限公司 | 济南办公室装修-厂房装修-商铺装修-工装公司-山东鲁工装饰设计 | 立式硫化罐-劳保用品硫化罐-厂家直销-山东鑫泰鑫硫化罐厂家 | 北京网站建设首页,做网站选【优站网】,专注北京网站建设,北京网站推广,天津网站建设,天津网站推广,小程序,手机APP的开发。 | UV固化机_UVLED光固化机_UV干燥机生产厂家-上海冠顶公司专业生产UV固化机设备 | 低温柔性试验仪-土工布淤堵-沥青车辙试验仪-莱博特(天津)试验机有限公司 | 工装定制/做厂家/公司_工装订做/制价格/费用-北京圣达信工装 | bng防爆挠性连接管-定做金属防爆挠性管-依客思防爆科技 | 电动卫生级调节阀,电动防爆球阀,电动软密封蝶阀,气动高压球阀,气动对夹蝶阀,气动V型调节球阀-上海川沪阀门有限公司 | 英国雷迪地下管线探测仪-雷迪RD8100管线仪-多功能数字听漏仪-北京迪瑞进创科技有限公司 | 合肥废气治理设备_安徽除尘设备_工业废气处理设备厂家-盈凯环保 合肥防火门窗/隔断_合肥防火卷帘门厂家_安徽耐火窗_良万消防设备有限公司 | 便携式高压氧舱-微压氧舱-核生化洗消系统-公众洗消站-洗消帐篷-北京利盟救援 | 压片机_高速_单冲_双层_花篮式_多功能旋转压片机-上海天九压片机厂家 | 广州活动策划公司-15+年专业大型公关活动策划执行管理经验-睿阳广告 | 咖啡加盟,咖啡店加盟连锁品牌-卡小逗 | 中国玩具展_玩具展|幼教用品展|幼教展|幼教装备展 | 国产离子色谱仪,红外分光测油仪,自动烟尘烟气测试仪-青岛埃仑通用科技有限公司 | 骨密度仪-骨密度测定仪-超声骨密度仪-骨龄测定仪-天津开发区圣鸿医疗器械有限公司 | PSI渗透压仪,TPS酸度计,美国CHAI PCR仪,渗透压仪厂家_价格,微生物快速检测仪-华泰和合(北京)商贸有限公司 | 橡胶弹簧|复合弹簧|橡胶球|振动筛配件-新乡市永鑫橡胶厂 | 高温高压釜(氢化反应釜)百科 | 膜片万向弹性联轴器-冲压铸造模具「沧州昌运模具」 | 浴室柜-浴室镜厂家-YINAISI · 意大利设计师品牌 | 咿耐斯 |-浙江台州市丰源卫浴有限公司 | 半容积式换热器_北京浮动盘管换热器厂家|北京亿丰上达 | 带式过滤机厂家_价格_型号规格参数-江西核威环保科技有限公司 | 清管器,管道清管器,聚氨酯发泡球,清管球 - 承德嘉拓设备 | 不锈钢丸厂家,铝丸,铸钢丸-淄博智源铸造材料有限公司 | 液晶拼接屏厂家_拼接屏品牌_拼接屏价格_监控大屏—北京维康 | 液压升降平台_剪叉式液压/导轨式升降机_传菜机定做「宁波日腾升降机厂家」 | 安平县鑫川金属丝网制品有限公司,声屏障,高速声屏障,百叶孔声屏障,大弧形声屏障,凹凸穿孔声屏障,铁路声屏障,顶部弧形声屏障,玻璃钢吸音板 | 沈阳激光机-沈阳喷码机-沈阳光纤激光打标机-沈阳co2激光打标机 | 英国雷迪地下管线探测仪-雷迪RD8100管线仪-多功能数字听漏仪-北京迪瑞进创科技有限公司 | 酒精检测棒,数显温湿度计,酒安酒精测试仪,酒精检测仪,呼气式酒精检测仪-郑州欧诺仪器有限公司 | 四川职高信息网-初高中、大专、职业技术学校招生信息网 | 扫地车厂家-山西洗地机-太原电动扫地车「大同朔州吕梁晋中忻州长治晋城洗地机」山西锦力环保科技有限公司 | 电镀整流器_微弧氧化电源_高频电解电源_微弧氧化设备厂家_深圳开瑞节能 | 污水处理设备维修_污水处理工程改造_机械格栅_过滤设备_气浮设备_刮吸泥机_污泥浓缩罐_污水处理设备_污水处理工程-北京龙泉新禹科技有限公司 | 陕西自考报名_陕西自学考试网 | 称重传感器,测力传感器,拉压力传感器,压力变送器,扭矩传感器,南京凯基特电气有限公司 |