lws-minimal-ws-server前端分析

index.html

index.html是前端入口

<html><head><meta charset=utf-8 http-equiv="Content-Language" content="en"/><!-- 引入js --><script src="/example.js"></script></head><body><img src="libwebsockets.org-logo.svg"><img src="strict-csp.svg"><br>LWS chat <b>minimal ws server example</b>.<br>Chat is sent to all browsers open on this page.<br><br><!-- 文本框 --><textarea id=r readonly cols=40 rows=10></textarea><br><!-- 输入框 --><input type="text" id=m cols=40 rows=1><!-- 发送按键 --><button id=b>Send</button></body>
</html>

example.js

example.js 为index.html提供了处理的逻辑


function get_appropriate_ws_url(extra_url)
{var pcol;// 获得页面上的urlvar u = document.URL;/** We open the websocket encrypted if this page came on an* https:// url itself, otherwise unencrypted*/// 去掉http://或者https://if (u.substring(0, 5) === "https") {pcol = "wss://";u = u.substr(8);} else {pcol = "ws://";if (u.substring(0, 4) === "http")u = u.substr(7);}// 去掉/后面的u = u.split("/");/* + "/xxx" bit is for IE10 workaround *///回来的url就城了ws://地址或者wss://地址return pcol + u[0] + "/" + extra_url;
}//创建ws服务
function new_ws(urlpath, protocol)
{return new WebSocket(urlpath, protocol);
}//加载监听
document.addEventListener("DOMContentLoaded", function() {//创建ws服务var ws = new_ws(get_appropriate_ws_url(""), "lws-minimal");try {//ws启动时ws.onopen = function() {//不禁用输入框和按键document.getElementById("m").disabled = 0;document.getElementById("b").disabled = 0;};//ws接收到数据包时ws.onmessage =function got_packet(msg) {//把收到的内容写到文本框加回车document.getElementById("r").value =document.getElementById("r").value + msg.data + "\n";//调整scrollTopdocument.getElementById("r").scrollTop =document.getElementById("r").scrollHeight;};//ws连接关闭时ws.onclose = function(){// 输入框和发送按键禁用document.getElementById("m").disabled = 1;document.getElementById("b").disabled = 1;};} catch(exception) {alert("<p>Error " + exception);  }//按键点击发送function sendmsg(){//发送内容ws.send(document.getElementById("m").value);//清空内容document.getElementById("m").value = "";}//为b按键增加一个click监听document.getElementById("b").addEventListener("click", sendmsg);}, false);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/897953.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

L1-7 统一命名规范(java)

你所在的公司刚刚招收了几位程序员&#xff0c;然而这些程序员之前在不同的公司工作&#xff0c;所以他们习惯的变量命名规范可能存在差异&#xff0c;需要让他们都习惯公司要求的命名规范&#xff0c;然而这样可能会降低他们的工作效率。 你的上司找到了你&#xff0c;希望你…

Flexus应用服务器L实例、X实例以及ECS(弹性计算服务)之间的区别及其适用场景

为了更好地理解Flexus应用服务器L实例、X实例以及ECS&#xff08;弹性计算服务&#xff09;之间的区别及其适用场景&#xff0c;下面我将通过具体的例子来说明每种类型的使用情况。 1. Flexus L实例 特点: 针对高并发和负载均衡进行了优化。它可能包括更快的网络接口、更高效…

WebRTC中音视频服务质量QoS之RTT衡量网络往返时延的加权平均RTT计算机制‌详解

WebRTC中音视频服务质量QoS之RTT衡量网络往返时延加权平均RTT计算机制‌的详解 WebRTC中音视频服务质量QoS之RTT衡量网络往返时延加权平均RTT计算机制‌的详解 WebRTC中音视频服务质量QoS之RTT衡量网络往返时延加权平均RTT计算机制‌的详解前言一、 RTT 网络往返时延的原理‌1、…

odbus TCP转Modbus RTU网关快速配置案例

Modbus TCP 转Modbus RTU网关快速配置案例 在工业自动化领域&#xff0c;Modbus 协议以其简洁和高效而著称&#xff0c;成为众多设备通信的首选。 随着技术的发展和应用场景的变化&#xff0c;Modbus 协议也发展出了不同的版本&#xff0c;其中 Modbus TCP 和 Modbus RTU 是两种…

《高效迁移学习:Keras与EfficientNet花卉分类项目全解析》

从零到精通的迁移学习实战指南&#xff1a;以Keras和EfficientNet为例 一、为什么我们需要迁移学习&#xff1f; 1.1 人类的学习智慧 想象一下&#xff1a;如果一个已经会弹钢琴的人学习吉他&#xff0c;会比完全不懂音乐的人快得多。因为TA已经掌握了乐理知识、节奏感和手指…

WSL2 Ubuntu安装GCC不同版本

WSL2 Ubuntu安装GCC不同版本 介绍安装gcc 7.1方法 1&#xff1a;通过源码编译安装 GCC 7.1步骤 1&#xff1a;安装编译依赖步骤 2&#xff1a;下载 GCC 7.1 源码步骤 3&#xff1a;配置和编译步骤 4&#xff1a;配置环境变量步骤 5&#xff1a;验证安装 方法 2&#xff1a;通过…

淘宝API vs 爬虫:合规获取实时商品数据的成本与效率对比

以下是淘宝 API 和爬虫在合规获取实时商品数据方面的成本与效率对比&#xff1a; 成本对比 淘宝 API 开发成本&#xff1a;需要申请开发者账号并获取 API 权限&#xff0c;部分敏感或高频访问的接口可能需要额外的审核或付费。开发过程中需要按照平台规定进行编程&#xff0c;相…

Android 手机启动过程

梳理 为了梳理思路&#xff0c;笔者画了一幅关于 Android 手机启动的过程图片内容纯属个人见解&#xff0c;如有错误&#xff0c;欢迎各位指正

【Linux】:封装线程

朋友们、伙计们&#xff0c;我们又见面了&#xff0c;本期来给大家带来封装线程相关的知识点&#xff0c;如果看完之后对你有一定的启发&#xff0c;那么请留下你的三连&#xff0c;祝大家心想事成&#xff01; C 语 言 专 栏&#xff1a;C语言&#xff1a;从入门到精通 数据结…

正则表达式全解析 + Java常用示例

目录 一、正则表达式基础&#xff08;一&#xff09;元字符&#xff08;二&#xff09;字符集&#xff08;三&#xff09;量词 二、正则表达式常用示例&#xff08;一&#xff09;验证邮箱格式&#xff08;二&#xff09;验证电话号码格式&#xff08;三&#xff09;提取网页中…

LoRa数传、点对点通信、Mesh网络、ZigBee以及图传技术的区别和特点

以下是LoRa数传、点对点通信、Mesh网络、ZigBee以及图传技术的区别和特点&#xff1a; 1.LoRa数传• 特点&#xff1a;LoRa是一种基于扩频技术的低功耗广域网&#xff08;LPWAN&#xff09;通信技术&#xff0c;具有传输距离远&#xff08;城市环境可达2-5公里&#xff0c;乡村…

星越L_三角指示牌及危险警示灯使用

目录 1.打开危险警告灯 2.取出反光背心穿上 3.取出指示牌 4.放置三角指示牌。 1.打开危险警示灯 2.取出反光背心穿上 3.取出指示牌

AI与人的智能,改变一生的思维模型【7】易得性偏差

目录 **易得性偏差思维模型&#xff1a;大脑的「热搜算法」与反操纵指南****病毒式定义&#xff1a;你的大脑正在被「热搜」劫持****四大核心攻击路径与史诗级案例****1. 信息过载时代的「认知短路」****2. 媒体放大器的「恐怖滤镜」****3. 个人经验的「数据暴政」****4. 社交茧…

Jmeter的简单使用

前置工作 确保java8 版本以上jmeter下载路径&#xff08;选择Binaries&#xff09;&#xff1a;https://jmeter.apache.org/download_jmeter.cgi直接解压&#xff0c;找到bin下面的文件&#xff1a;jmeter.bat&#xff08;可选&#xff09;汉化&#xff0c;修改 jmeter.proper…

MyBatis源码分析の配置文件解析

文章目录 前言一、SqlSessionFactoryBuilder1.1、XMLConfigBuilder1.2、parse 二、mappers标签的解析2.1、cacheElement2.1.1、缓存策略 2.2、buildStatementFromContext2.2.1、sql的解析 前言 本篇主要介绍MyBatis源码中的配置文件解析部分。MyBatis是对于传统JDBC的封装&…

golang快速上手基础语法

变量 第一种&#xff0c;指定变量类型&#xff0c;声明后若不赋值&#xff0c;使用默认值0 package mainimport "fmt"func main() {var a int //第一种&#xff0c;指定变量类型&#xff0c;声明后若不赋值&#xff0c;使用默认值0。fmt.Printf(" a %d\n"…

Java中的访问修饰符有哪些

在 Java 中&#xff0c;访问修饰符&#xff08;Access Modifiers&#xff09;用于控制类、方法、变量和构造器的访问权限。Java 提供了四种访问修饰符&#xff0c;分别是&#xff1a; publicprotecteddefault&#xff08;包私有&#xff0c;没有显式修饰符&#xff09;private…

【公务员考试】高效备考指南

高效备考指南&#xff1a;从计划制定到心态调整的全面攻略 公务员考试竞争激烈&#xff0c;备考过程既需要科学规划&#xff0c;也需要持之以恒的努力。结合多位高分考生的经验与专业机构的指导&#xff0c;本文整理了一套系统化的备考策略&#xff0c;涵盖目标设定、学习方法…

工程实践:如何使用SU17无人机来实现室内巡检任务

阿木实验室最近发布了科研开发者版本的无人机SU17&#xff0c;该无人机上集成了四目视觉&#xff0c;三维激光雷达&#xff0c;云台吊舱&#xff0c;高算力的机载计算机&#xff0c;是一个非常合适的平台用于室内外巡检场景。同时阿木实验室维护了多个和无人机相关的开源项目。…

强大的CSS变量

在 CSS 中&#xff0c;变量&#xff08;Custom Properties&#xff09; 允许你定义可重用的值&#xff0c;方便在整个样式表中使用和修改。CSS 变量的基本语法如下&#xff1a; 1. 定义 CSS 变量 CSS 变量通常在 :root 伪类中定义&#xff0c;以便它们可用于整个文档&#xf…