当前位置: 首页 > news >正文

怎样在网站上做办公家具什么是前端开发和后端开发

怎样在网站上做办公家具,什么是前端开发和后端开发,企业官方网站建设目的,北京网站建设推荐华网天下首先是客户端,看着比较简单。但实际应用中可能要比这复杂,因为默认sse只支持get请求,而且没法携带header。所以如果默认的方法达不到需求的话可能需要额外实现,当然也可以引用第三方库,比如rangermauve/fetch-event-so…

首先是客户端,看着比较简单。但实际应用中可能要比这复杂,因为默认sse只支持get请求,而且没法携带header。所以如果默认的方法达不到需求的话可能需要额外实现,当然也可以引用第三方库,比如@rangermauve/fetch-event-source。所以有谁会自己实现呢?

if(typeof(EventSource)!=="undefined")
{var source=new EventSource("http://localhost:9001");source.onopen = function(event) {console.log("onopen")};source.onmessage=function(event){console.log("onmessage");console.log("data is ", event.data);document.getElementById("result").innerHTML=event.data + "<br>";};
}
else
{// 浏览器不支持 server-sent 事件
}

服务端java代码如下:

package com.zhouz.signing.controller.v1;import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.CrossOrigin;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.Date;@RestController
@CrossOrigin
public class TestController {protected static Logger logger = LoggerFactory.getLogger(UserController.class);@RequestMapping(value = "/testsse")@ResponseBodypublic void getStreamDataImprove(HttpServletResponse httpServletResponse) {httpServletResponse.setContentType("text/event-stream"); // content-type必须是text/event-streamhttpServletResponse.setCharacterEncoding("utf-8"); // 编码必须是utf-8// 这里用死循环是为了和客户端建立长连接while (true) {String s = "retry:10000\n"; // retry:后面跟单位为毫秒的数字,客户端会在断开连接后按照设置的毫秒数进行重连String i = new Date().toString();s += "id:" + i + "\n"; // id: 设置id,可以在比如客户端网络错误的时候下一次再连接时向服务端发送的请求中header中带有Last-Event-Id参数,服务端拿到这个值就可以将未推送的数据再次推送给客户端s += "data:" + i + "\n\n"; // data: 设置数据,注意一则消息的最后必须要有两个换行符try {PrintWriter pw = httpServletResponse.getWriter();Thread.sleep(1000L); // 如果不想给客户端发送消息过于频繁,可以设置等待时间pw.write(s);pw.flush();if (pw.checkError()) {logger.info("客户端断开连接");break; // 判断出错后,需要结束死循环,本次请求也就结束了。}} catch (IOException | InterruptedException e) {e.printStackTrace();}}}
}

服务端php代码

<?php
header("Access-Control-Allow-Origin: *");
header("Access-Control-Allow-Methods: *");
header('Content-Type: text/event-stream');
header('Cache-Control: no-cache');while(true) {$time = date('r');echo "data: {$time}\n\n";ob_flush();flush();sleep(1);// TODO 这里不知道是否可以用这个方法来判断客户端断开了连接if (connection_aborted()) {break;}
}

需要注意的是,如果服务端不加死循环,前端看着是3秒发起一个请求。而加了死循环之后,前端实际上只发送了一次请求。

http://www.yayakq.cn/news/527919/

相关文章:

  • 做专业慢摇的网站怎么做点击图片进入网站
  • 网站建设哪里好点网站首页排名下降
  • 微商城网站建设报价电子商务网站设计中影响客户体验的元素有
  • 网站建设_app开发网站建设和网络推广外包
  • 中小学生做的网站上海工商网站查询企业信息
  • 汝州建站公司互联网运营培训课程
  • 做网站和app多少费用国际新闻最新新闻
  • 电商网站公司济宁网站建设公司
  • 校园官方网站建设的书籍江苏建设信息网官网
  • 手机视频网站设计专业长春网站建设
  • .net网站开发全过程wordpress 获取文章图片标题
  • 宁波网站建设首选品牌台州网站哪家专业
  • 郑州微网站宜昌外贸网站建设优化推广
  • 30秒网站杭州网站开发公司排名
  • 珠海建网站什么网站免费建设
  • 想搞网站建设福安 网站建设
  • 怎么做自动提卡网站安徽省建设工程信息网平台官网
  • 广州 网站制作购票网站模板
  • wordpress4.2.8 留言本南宁seo外包服务商
  • 网站推广优化建设清博大数据舆情监测平台
  • 有没有学做ppt发网站或论坛vi设计公司 成都
  • 响应式的网站建设一个多少钱运动鞋子网站建设规划书
  • 网站建设定制开发价格人像摄影网站十大排名
  • 麦吉太原网站建设丽怎么代理广州市新闻发布
  • 长沙哪家做网站设计好云南楚雄医药高等专科学校
  • 企业网站建设与管理简述网站的平面设计图用ps做
  • 南通通州区网站制作wordpress安装目录
  • 在线科技成都网站推广公司海洋cms做电影网站好做吗
  • 苏州网站托管网络广告的特点有哪些?
  • 网站做哪些比较赚钱微信公众小程序开发