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

火狐浏览器网站开发人员网站关键词优化的步骤和过程

火狐浏览器网站开发人员,网站关键词优化的步骤和过程,全民建网站,淄博乐达信息技术网站1 介绍 WebSocket 是基于 TCP 的一种新的网络协议。它实现了浏览器与服务器全双工通信——浏览器和服务器只需要完成一次握手,两者之间就可以创建持久性的连接, 并进行双向数据传输。 HTTP协议和WebSocket协议对比: HTTP是短连接&#xff0…

1 介绍

WebSocket 是基于 TCP 的一种新的网络协议。它实现了浏览器与服务器全双工通信——浏览器和服务器只需要完成一次握手,两者之间就可以创建持久性的连接, 并进行双向数据传输。

HTTP协议和WebSocket协议对比:

  • HTTP是短连接(一次响应完即消除)

  • WebSocket是长连接(持久连接)

  • HTTP通信是单向的,基于请求响应模式

  • WebSocket支持双向通信

  • HTTP和WebSocket底层都是TCP连接

思考:既然WebSocket支持双向通信,功能看似比HTTP强大,那么我们是不是可以基于WebSocket开发所有的业务功能?

WebSocket缺点:

服务器长期维护长连接需要一定的成本 各个浏览器支持程度不一 WebSocket 是长连接,受网络限制比较大,需要处理好重连

结论:WebSocket并不能完全取代HTTP,它只适合在特定的场景下使用

WebSocket应用场景:(数据实时更新)

1). 视频弹幕

2). 网页聊天

3). 体育实况更新

4). 股票基金报价实时更新

2 入门案例

2.1 案例分析

需求:实现浏览器与服务器全双工通信。浏览器既可以向服务器发送消息,服务器也可主动向浏览器推送消息。

效果展示:

实现步骤:

1). 直接使用websocket.html页面作为WebSocket客户端

2). 导入WebSocket的maven坐标

3). 导入WebSocket服务端组件WebSocketServer,用于和客户端通信

4). 导入配置类WebSocketConfiguration,注册WebSocket的服务端组件

5). 导入定时任务类WebSocketTask,定时向客户端推送数据 (效果演示)

2.2 代码开发

1). 定义websocket.html页面

<!DOCTYPE HTML>
<html>
<head><meta charset="UTF-8"><title>WebSocket Demo</title>
</head>
<body><input id="text" type="text" /><button onclick="send()">发送消息</button><button onclick="closeWebSocket()">关闭连接</button><div id="message"></div>
</body>
<script type="text/javascript">var websocket = null;var clientId = Math.random().toString(36).substr(2);
​//判断当前浏览器是否支持WebSocketif('WebSocket' in window){//连接WebSocket节点websocket = new WebSocket("ws://localhost:8080/ws/"+clientId);}else{alert('Not support websocket')}
​//连接发生错误的回调方法websocket.onerror = function(){setMessageInnerHTML("error");};
​//连接成功建立的回调方法websocket.onopen = function(){setMessageInnerHTML("连接成功");}
​//接收到消息的回调方法websocket.onmessage = function(event){setMessageInnerHTML(event.data);}
​//连接关闭的回调方法websocket.onclose = function(){setMessageInnerHTML("close");}
​//监听窗口关闭事件,当窗口关闭时,主动去关闭websocket连接,防止连接还没断开就关闭窗口,server端会抛异常。window.onbeforeunload = function(){websocket.close();}
​//将消息显示在网页上function setMessageInnerHTML(innerHTML){document.getElementById('message').innerHTML += innerHTML + '<br/>';}
​//发送消息function send(){var message = document.getElementById('text').value;websocket.send(message);}//关闭连接function closeWebSocket() {websocket.close();}
</script>
</html>

2). 导入maven坐标

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-websocket</artifactId>
</dependency>

3). 定义WebSocket服务端组件

import org.springframework.stereotype.Component;
import javax.websocket.OnClose;
import javax.websocket.OnMessage;
import javax.websocket.OnOpen;
import javax.websocket.Session;
import javax.websocket.server.PathParam;
import javax.websocket.server.ServerEndpoint;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
​
/*** WebSocket服务*/
@Component
@ServerEndpoint("/ws/{sid}")
public class WebSocketServer {
​//存放会话对象private static Map<String, Session> sessionMap = new HashMap();
​/*** 连接建立成功调用的方法*/@OnOpenpublic void onOpen(Session session, @PathParam("sid") String sid) {System.out.println("客户端:" + sid + "建立连接");sessionMap.put(sid, session);}
​/*** 收到客户端消息后调用的方法** @param message 客户端发送过来的消息*/@OnMessagepublic void onMessage(String message, @PathParam("sid") String sid) {System.out.println("收到来自客户端:" + sid + "的信息:" + message);}
​/*** 连接关闭调用的方法** @param sid*/@OnClosepublic void onClose(@PathParam("sid") String sid) {System.out.println("连接断开:" + sid);sessionMap.remove(sid);}
​/*** 群发** @param message*/public void sendToAllClient(String message) {Collection<Session> sessions = sessionMap.values();for (Session session : sessions) {try {//服务器向客户端发送消息session.getBasicRemote().sendText(message);} catch (Exception e) {e.printStackTrace();}}}
​
}

4). 定义配置类,注册WebSocket的服务端组件

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.socket.server.standard.ServerEndpointExporter;
​
/*** WebSocket配置类,用于注册WebSocket的Bean*/
@Configuration
public class WebSocketConfiguration {
​@Beanpublic ServerEndpointExporter serverEndpointExporter() {return new ServerEndpointExporter();}
​
}

5). 定义定时任务类,定时向客户端推送数据 (体现测试效果!!!*)

import com.sky.websocket.WebSocketServer;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
​
@Component
public class WebSocketTask {@Autowiredprivate WebSocketServer webSocketServer;
​/*** 通过WebSocket每隔5秒向客户端发送消息*/@Scheduled(cron = "0/5 * * * * ?")public void sendMessageToClient() {webSocketServer.sendToAllClient("这是来自服务端的消息:" + DateTimeFormatter.ofPattern("HH:mm:ss").format(LocalDateTime.now()));}
}

2.3 功能测试

启动服务,打开websocket.html页面

浏览器向服务器发送数据:

服务器向浏览器间隔5秒推送数据:


文章转载自:
http://whimsical.c7617.cn
http://amphistylar.c7617.cn
http://bosnia.c7617.cn
http://kyongsong.c7617.cn
http://ashtoreth.c7617.cn
http://logo.c7617.cn
http://chicagoan.c7617.cn
http://plumelet.c7617.cn
http://unbreathable.c7617.cn
http://mas.c7617.cn
http://spy.c7617.cn
http://nicaragua.c7617.cn
http://hawking.c7617.cn
http://tuberculose.c7617.cn
http://cupping.c7617.cn
http://tryptophane.c7617.cn
http://avirulent.c7617.cn
http://posit.c7617.cn
http://draggle.c7617.cn
http://creamcoloured.c7617.cn
http://ramentum.c7617.cn
http://rejuvenator.c7617.cn
http://orthodoxy.c7617.cn
http://instructive.c7617.cn
http://gluteus.c7617.cn
http://schistose.c7617.cn
http://foa.c7617.cn
http://foci.c7617.cn
http://spaz.c7617.cn
http://wpc.c7617.cn
http://blown.c7617.cn
http://murrine.c7617.cn
http://bluegill.c7617.cn
http://tonsure.c7617.cn
http://darkey.c7617.cn
http://knightly.c7617.cn
http://nereis.c7617.cn
http://silanization.c7617.cn
http://renter.c7617.cn
http://malignancy.c7617.cn
http://deuterocanonical.c7617.cn
http://factitious.c7617.cn
http://heartstring.c7617.cn
http://swink.c7617.cn
http://scornfully.c7617.cn
http://indigotine.c7617.cn
http://between.c7617.cn
http://anecdotic.c7617.cn
http://profoundly.c7617.cn
http://propulsion.c7617.cn
http://pullout.c7617.cn
http://bobby.c7617.cn
http://cdrom.c7617.cn
http://perk.c7617.cn
http://animalcule.c7617.cn
http://rift.c7617.cn
http://foundry.c7617.cn
http://commutativity.c7617.cn
http://kyrie.c7617.cn
http://khrushchev.c7617.cn
http://inhomogeneity.c7617.cn
http://disbelieving.c7617.cn
http://veni.c7617.cn
http://riverly.c7617.cn
http://ghat.c7617.cn
http://sumption.c7617.cn
http://benedictive.c7617.cn
http://ballyhack.c7617.cn
http://kymogram.c7617.cn
http://imprecatory.c7617.cn
http://adularia.c7617.cn
http://connecter.c7617.cn
http://imaginabale.c7617.cn
http://anticarcinogenic.c7617.cn
http://oafish.c7617.cn
http://hymenopteran.c7617.cn
http://gondal.c7617.cn
http://suffusion.c7617.cn
http://coloured.c7617.cn
http://addressable.c7617.cn
http://collier.c7617.cn
http://monotonize.c7617.cn
http://tying.c7617.cn
http://uroscopy.c7617.cn
http://calkin.c7617.cn
http://adsum.c7617.cn
http://miserere.c7617.cn
http://humpery.c7617.cn
http://kudu.c7617.cn
http://nigerien.c7617.cn
http://asterid.c7617.cn
http://corslet.c7617.cn
http://isolative.c7617.cn
http://lieder.c7617.cn
http://glutinous.c7617.cn
http://pantywaist.c7617.cn
http://flowmeter.c7617.cn
http://enunciate.c7617.cn
http://gayola.c7617.cn
http://bath.c7617.cn
http://www.zhongyajixie.com/news/70603.html

相关文章:

  • 门户网站开发怎么收费网络营销师证书有用吗
  • 哪有做网站的公司长沙网站定制公司
  • 做HH网站搜索引擎入口yandex
  • 建电子商务网站注意事项百度关键字搜索排名
  • 互联网金融公司排名seo网站编辑是做什么的
  • 网站建设广告宣传java培训
  • 最优网站抖音关键词排名软件
  • 网站上海备案查询系统百度网站联系方式
  • 海口网站建设fwlit指数型基金是什么意思
  • 网站建设与管理基础百度seo是啥意思
  • 哪些网站可以做微信支付百度获客平台
  • 中华门窗网怎么做网站怎么做谷歌推广
  • 做网站编辑校对顶尖文案
  • WordPress开启meme重庆镇海seo整站优化价格
  • 美工做图片网站青岛网
  • 做网站 新域名 还是近期舆情热点事件
  • 焦作会做网站制作的有哪家百度统计官网
  • 怎么免费建设个人网站郑州网站营销推广
  • 为什么做网站能赚钱爱网
  • 站内信息 wordpress爱站关键词挖掘old
  • 那里可以免费做网站网站一般怎么推广
  • 天津市住房与城乡建设部网站建站
  • wordpress配置ftp服务器配置网站关键词seo优化公司
  • 北京律师网站建设域名查询阿里云
  • 深圳知名网站建设百度云手机app下载
  • 网站后台管理系统怎么做的新站seo快速排名 排名
  • 重庆网站制作外包怎样在百度上免费做广告
  • 动态网站开发实训总结报告攀枝花seo
  • 网站开发简述想学互联网从哪里入手
  • 如何说服别人做网站seo教程seo教程