我的编程空间,编程开发者的网络收藏夹
学习永远不晚

HTML5 WebSockets怎么使用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

HTML5 WebSockets怎么使用

今天小编给大家分享一下HTML5 WebSockets怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

  什么是WebSockets?

  WebSockets是在一个(TCP)接口进行双向通信的技术,PUSH技术类型。同时WebSockets仍将基于W3C标准,目前为止,Chrome和Safari的最新版本浏览器已经支持WebSockets了。

  WebSockets将会替代什么?

  WebSockets可以替代Long Polling(PHP服务端推送技术),这是一个有趣的概念。客户端发送一个请求到服务器,现在,服务器端并不会响应还没准备好的数据,它会保持连接的打开状态直到最新的数据准备就绪发送,之后客户端收到数据,然后发送另一个请求。这有它的好处:减少任一连接的延迟,当一个连接已经打开时就不需要创建另一个新的连接。但是Long-Polling并不是什么花俏技术,他仍有可能发生请求暂停,因此会需要建立新的连接。

  一些AJAX应用使用上述技术-这经常是归因于低资源利用。

  试想一下,如果服务器在早晨会自启动并发送数据到那些希望接收而不用提前建立一些连接端口的客户端,这是一件多棒的事情啊!欢迎来到PUSH技术的世界!

  第一步:搞定WebSocket服务器

  这篇教程会把更多的精力放在客户端的创建而不是服务器端的执行等操作。

  我使用基于windows 7的XAMPP来实现本地运行PHP。phpwebsockets是PHP WebSocket服务器。(以我的经验这个版本存在一些小问题,我已对它做了些修改并上传源文件共享给大家)下面的这些不同版本也可以实现WebSocket,如果某个不能用,你可以试试其它版本或者继续看下面的教程。

  jWebSocket?(Java)

  web-socket-ruby(ruby)

  Socket IO-node?(node.js)

  启动Apache服务器

  第二步:修改URLs和端口

  根据你之前的安装修改服务器,下面是setup.class.php中的例子:

  浏览文件并在适当情况下进行更改。

  第三步:开始创建客户端

  下面来创建基本模板,这是我的client.php文件:

  我们已经创建里基本模板:一个chat log容器,一个input输入框和一个断开连接的按钮。

  第四步:添加一些CSS

  没什么花俏代码,只是处理一下标签的样式。

  第五步:WebSocket事件

  首先让我们尝试并理解WebSocket事件的概念:

  WebSocket事件:

  我们将使用三个WebSocket事件:

  onopen: 当接口打开时onmessage: 当收到信息时onclose: 当接口关闭时

  我们如何来实现呢?

  首先创建WebSocket对象

  然后向下面这样检测事件

  3 }

  但我们还是尽量避免使用alert,现在我们可以把我们学的东西整合到客户端页面中了。

  第六步:JavaScript

  首先我们将代码放到jQuery的 document.ready函数中,然后我们还要检查用户的浏览器是否支持WebSocket。如果不支持,我们就添加一个链向Chrome浏览器页面的链接。

  如你所见,如果用户浏览器支持WebSocket,我们将执行connect()函数。这里是核心功能,我们将开始创建open、close和receive事件。

  我们将在我们的服务器定义URL。

  你可能会发现URL中怎么没有http?恩,是的,这是一个WebSocket URL,使用了不同的协议。下面是URL分解图示:

  下面让我们继续完成connect()函数,我们将代码放入try/catch块,这样如果代码出现问题,我们能让用户知道。我们创建WebSocket,并将信息传递到message()函数,之后会做讲解。我们创建我们的onopen、onmessage和onclose函数.需要注意的是我们为用户提供了端口状态,这并不是必需的,但我们把它放进来主要是为了方便调试。

  CONNECTING = 0OPEN = 1CLOSED = 2

  message()函数很简单,它将我们想展现给用户的文本填入chat log容器内。我们在socket事件函数中为段落(<p>)标签创建适当的class,我们在message函数中只有一个段落结束标签。

  目前的成果

  如果你已按上面教程按部就班的做的话,很好,我们已经创建了 HTML/CSS 模板、创建并建立Websocket连接、通过创建连接保持用户的进展更新。

  第七步:发送数据

  现在我们已经有了提交按钮,但我们还需要监听用户按下键盘的事件,并运行send函数,下面的&rsquo;13&prime;便是回车键对应的ASCII码。

  下面是send()函数:

  下面我们需要:

  那些额外的代码做了以下工作:检测用户是否什么都没输入却仍点击返回、清空input输入框、执行message()函数。

  关闭Socket

  关闭Socket操作相当简单,添加对断开连接按钮的click事件监听就可以。

  完整JavaScript代码

  第九步:运行WebSocket服务器

  我们要输入一些命令行,XAMPP提供了比较方便的shell选项。点击XAMPP控制面板的&rsquo;shell&rsquo;按钮并输入:php -q path\to\server.php现在你已经运行了WebSocket服务器!

以上就是“HTML5 WebSockets怎么使用”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

HTML5 WebSockets怎么使用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

怎么使用laravel-websockets实现广播系统

本篇内容介绍了“怎么使用laravel-websockets实现广播系统”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!创建项目在 Apach
2023-07-04

Go怎么实现WebSockets

这篇文章主要介绍了Go怎么实现WebSockets的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Go怎么实现WebSockets文章都会有所收获,下面我们一起来看看吧。什么是 WebSockets简而言之,We
2023-06-30

html5怎么使用

随着移动设备的普及和互联网的快速发展,HTML5最近成为了互联网界的一个重要话题。HTML5是HTML(Hyper Text Markup Language)的第五个版本,它的发布引发了将近十年来最大的一次浏览器变革。HTML5不仅拓展了Web应用的功能,而且也减少了无数的安全漏洞。那么,在实际项目开发中,HTML5具体如何运用呢?本文将为您通过简明易懂的方式详细介绍一下。一、
2023-05-15

WebSockets技术有什么作用

这篇文章主要讲解了“WebSockets技术有什么作用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“WebSockets技术有什么作用”吧!网站大部分都会用到通知,使用什么技术来实现通知比较
2023-06-26

html5中的base怎么使用

这篇文章主要介绍“html5中的base怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“html5中的base怎么使用”文章能帮助大家解决问题。html5中base标签的作用是为页面上的所有的
2023-07-05

如何使用 Gorilla Websockets 和 alexedwards/scs/v2 实现 http.Hijacker

php小编苹果今天为大家介绍一种使用Gorilla Websockets和alexedwards/scs/v2库来实现http.Hijacker的方法。这种方法可以帮助开发者在自己的应用程序中实现实时通信的功能,无论是聊天室还是实时更新等场
如何使用 Gorilla Websockets 和 alexedwards/scs/v2 实现 http.Hijacker
2024-02-10

SVG怎么在HTML5中使用

这期内容当中小编将会给大家带来有关SVG怎么在HTML5中使用,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。SVG的优势:SVG 可被非常多的工具读取和修改(比如记事本)SVG 与 JPEG 和 GIF
2023-06-09

viewport怎么在html5中使用

这篇文章给大家介绍 viewport怎么在html5中使用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。viewport 语法介绍:代码如下:
2023-06-09

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录