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

北京市网站设计-推广公司服装设计公司主要做什么

北京市网站设计-推广公司,服装设计公司主要做什么,南昌公司网站开发,太湖县住房和城乡建设网站市建设局WebSocket是HTML5下一种新的协议,它实现了浏览器与服务器全双工通信,能更好的节省服务器资源和带宽并达到实时通讯的目的 在很多项目中,都要用到websocket,使得前端页面与后端页进行实时通信,例如,实时查询…

WebSocket是HTML5下一种新的协议,它实现了浏览器与服务器全双工通信,能更好的节省服务器资源和带宽并达到实时通讯的目的

在很多项目中,都要用到websocket,使得前端页面与后端页进行实时通信,例如,实时查询订单状态、设备状态实时显示到页面。本博文,分为前端页面代码和后端页面代码,在最后有源代码下载链接。前端使用用vue技术,后端使用springboot

一、后端代码
1、websocket代码
@Slf4j
@Component
@ServerEndpoint(value = "/websocket/order")
public class WebsocketProvider {/*** 连接事件,加入注解* @param session*/@OnOpenpublic void onOpen(Session session) {String orderId = WebsocketUtil.getParam(WebsocketUtil.sessionKey, session);log.info("Websocket连接已打开,当前orderId为:"+orderId);// 添加到session的映射关系中WebsocketUtil.addSession(orderId, session);//测试发送消息WebsocketUtil.sendMessage(orderId, AjaxResult.success("恭喜,已建立连接"));}/*** 连接事件,加入注解* 用户断开链接* @param session*/@OnClosepublic void onClose(Session session) {String orderId = WebsocketUtil.getParam(WebsocketUtil.sessionKey, session);// 删除映射关系WebsocketUtil.removeSession(orderId);}/*** 当接收到用户上传的消息* @param session*/@OnMessagepublic void onMessage(Session session, String message) {log.info("收到Websocket消息:"+message);}/*** 处理用户活连接异常* @param session* @param throwable*/@OnErrorpublic void onError(Session session, Throwable throwable) {try {if (session.isOpen()) {session.close();}} catch (IOException e) {e.printStackTrace();}throwable.printStackTrace();}
}
2、controller发送代码
@Slf4j
@RestController
@RequestMapping("/send")
@Api(tags = "SendController", description = "发送管理")
public class SendController {/*** 相关信息**/@GetMappingpublic String getPayType(String data) {WebsocketUtil.sendMessage("123456", AjaxResult.success(data));return "发送成功";}
}
3、后端向前端发送消息代码
/*** 根据用户ID发送消息** @param result*/public static void sendMessage(String sessionId, AjaxResult result) {sendMessage(sessionId, JSON.toJSONString(result));}/*** 根据用户ID发送消息** @param message*/public static void sendMessage(String sessionId, String message) {Session session = ONLINE_SESSION.get(sessionId);//判断是否存在该用户的session,判断是否还在线if (session == null || !session.isOpen()) {return;}sendMessage(session, message);}
二、VUE前端代码
1、界面代码
<div style="display: flex;"><el-input v-model="sendData" placeholder="请输入要发送的内容"/><el-button type="success" @click="send" style="margin-left: 20px;">发送</el-button></div><div style="margin-top: 25px;margin-bottom: 5px;font-weight: bold;">收到的消息:</div><div v-for="(item,index) in messages"><span>{{item}}</span></div>
2、websocket相关代码
        console.log('进入状态监听*******')var url = payServerUrl+"?orderId="+orderId;//建立webSocket连接proxy.websocket = new WebSocket(url);//打开webSokcet连接时,回调该函数proxy.websocket.onopen = () =>{console.log("连接建立");} //关闭webSocket连接时,回调该函数proxy.websocket.onclose = () =>{console.log("连接关闭");} //接收信息proxy.websocket.onmessage = function (res) {var obj = eval('(' + res.data + ')');console.log(obj)proxy.messages.push(res.data)}
三、测试
1、后端服务启动,运行ServerApplication (运行前,maven先下载依赖包)

2、前端服务启动

window,运行cmd命令,进行前端页面文件夹,执行如下命令

(1)1、安装依赖包
npm install
(2)、启动服务
npm run dev

打开页面 :http://localhost:6080/#/index3、前端页向后端发送数据
4、后端向前端页面发送数据

​使用apifox来发发送请求,apifox百度下载即可
GET请求,http://localhost:8080/ck/send,数据为data

4、源代码:

链接:https://pan.baidu.com/s/1YnuBFQBt2O4GIdcs4jO1SA?pwd=8ahq 
提取码:8ahq

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

相关文章:

  • 网站开发编程的工作方法抖音代运营内容
  • 开发网站有什么用官方网站建设的目的
  • 河南郑州建网站公司2016个人做淘宝客网站
  • 网站搜索引擎优化情况怎么写网络营销的几种模式
  • 竹子建站免费版网站的建设与推广
  • 智能网站建设加工提高搜索引擎排名
  • 在线做漫画网站动漫制作这个专业怎么样
  • 优秀网站建设哪家好大望路网站制作
  • 湖州网站建设推广wordpress使用密码
  • 一个小型购物网站开发wordpress 加载很慢
  • 大兴建设网站网站建设的可行性要求
  • 建设积分商城网站东莞网络推广价格
  • 瓷砖网站源码城乡与住房建设部网站办事大厅
  • 厦门做网站多优秀网页设计导航
  • 深圳网站建设luony余姚做网站公司
  • 让网站建设便宜到底定制型网站制作哪家好
  • 在哪个网站可以做二建的题徐州建站模板
  • 建行官网网站工作表格excel下载
  • 大连建网站需要多少钱个人网站建设的论文
  • 崇安区网站建设价格网站建设主管招聘
  • 苏州做网站好的建设工程合同民法典
  • 注册网站刀具与钢材范围广州市工程交易中心官网
  • 永城做网站网站云服务器
  • 制作网站常用软件建设银官方网站
  • qq钓鱼网站生成器手机版建站网站赚钱吗
  • 重庆奉节网站建设公司wordpress菜单二级菜单
  • 网站建设管理规定wordpress主题kratos
  • 溧阳做网站的哪家好山东省建设官方网站
  • 我是做网站怎么赚钱wordpress页面如何设置新窗口打开
  • 有没有什么做地堆的网站法律服务网站建设