基于HTML5的WebSocket的实例代码


Posted in HTML / CSS onAugust 15, 2018

基于HTML5的WebSocket的实例代码

客户端代码:

<html>
<head>
<script>
var socket;
if ("WebSocket" in window) {
var ws = new WebSocket("ws://127.0.0.1:8181");
socket = ws;
ws.onopen = function() {
console.log('连接成功');
};
ws.onmessage = function(evt) {
var received_msg = evt.data; 
document.getElementById("showMes").value+=evt.data+"\n";
};
ws.onclose = function() {
alert("断开了连接");
};
} else {
alert("浏览器不支持WebSocket");
}
function login(){
var message=document.getElementById("name").value+":"+document.getElementById("mes").value;
socket.send(message);
}
</script>
</head>
<body>
<textarea rows="3" cols="30" id="showMes" style="width:300px;height:500px;"></textarea>
<br/>
<label>名称</label>
<input type="text" id="name"/>
<br/>
<label>消息</label>
<input type="text" id="mes"/>
<button onclick="login();">发送</button>
</body>
</html>

winform服务端代码:

注:需先引入Fleck包

基于HTML5的WebSocket的实例代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Windows.Forms;
using Fleck;
namespace socketService
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
CheckForIllegalCrossThreadCalls = false;
}
private void Form1_Load(object sender, EventArgs e)
{
//保存所有连接
var allSockets = new List<IWebSocketConnection>();
//初始化服务端
var server = new WebSocketServer("ws://0.0.0.0:8181");
//开始监听
server.Start(socket =>
{
//有客户端连接触发
socket.OnOpen = () =>
{
textBox3.Text += socket.ConnectionInfo.ClientIpAddress + " 连接 \r\n";
allSockets.Add(socket);
};
//有客户端断开触发
socket.OnClose = () =>
{
textBox3.Text += socket.ConnectionInfo.ClientIpAddress + " 断开连接 \r\n";
allSockets.Remove(socket);
};
//接收客户端发送的消息
socket.OnMessage = message =>
{
textBox3.Text += socket.ConnectionInfo.ClientIpAddress + " 发送了消息:" + message + "\r\n";
//发送接收到的消息给所有客户端
allSockets.ToList().ForEach(s => s.Send(message));
};
});
}
}
}

总结

以上所述是小编给大家介绍的基于HTML5的WebSocket的实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

HTML / CSS 相关文章推荐
CSS+jQuery+PHP+MySQL实现的在线答题功能
Apr 25 HTML / CSS
CSS3实现曲线阴影和翘边阴影
May 03 HTML / CSS
css3的过滤效果简单实例
Aug 03 HTML / CSS
使用CSS3 制作一个material-design 风格登录界面实例
Dec 12 HTML / CSS
CSS3贝塞尔曲线示例:创建链接悬停动画效果
Nov 19 HTML / CSS
详解基于 Canvas 手撸一个六边形能力图
Sep 02 HTML / CSS
canvas学习笔记之2d画布基础的实现
Feb 21 HTML / CSS
基于HTML5 FileSystem API的使用介绍
Apr 24 HTML / CSS
html标签之Object和EMBED标签详解
Jul 04 HTML / CSS
跨域修改iframe页面内容详解
Oct 31 HTML / CSS
div与span之间的区别与使用介绍
Dec 06 HTML / CSS
CSS使用Flex和Grid布局实现3D骰子
Aug 05 HTML / CSS
HTML5中canvas中的beginPath()和closePath()的重要性
Aug 24 #HTML / CSS
Html5移动端弹幕动画实现示例代码
Aug 27 #HTML / CSS
Html5页面在微信端的分享的实现方法
Aug 30 #HTML / CSS
canvas粒子动画背景的实现示例
Sep 03 #HTML / CSS
html5中去掉input type date默认样式的方法
Sep 06 #HTML / CSS
html5新特性与用法大全
Sep 13 #HTML / CSS
HTML5新控件之日期和时间选择输入的实现代码
Sep 13 #HTML / CSS
You might like
php修改时间格式的代码
2011/05/29 PHP
PHP中对于浮点型的数据需要用不同的方法解决
2014/03/11 PHP
使用PHP uniqid函数生成唯一ID
2015/11/18 PHP
Laravel学习教程之本地化模块
2017/08/18 PHP
ThinkPHP实现转换数据库查询结果数据到对应类型的方法
2017/11/16 PHP
javaScript同意等待代码实现心得
2011/01/01 Javascript
jquery防止重复执行动画避免页面混乱
2014/04/22 Javascript
Jquery图片延迟加载插件jquery.lazyload.js的使用方法
2014/05/21 Javascript
纯js实现div内图片自适应大小(已测试,兼容火狐)
2014/06/16 Javascript
js实现鼠标滚轮控制图片缩放效果的方法
2015/02/20 Javascript
JS实现控制表格行内容垂直对齐的方法
2015/03/30 Javascript
如何使用jQuery技术开发ios风格的页面导航菜单
2015/07/29 Javascript
JS更改select内option属性的方法
2015/10/14 Javascript
基于Jquery实现焦点图淡出淡入效果
2015/11/30 Javascript
jQuery继承extend用法详解
2016/10/10 Javascript
浅谈如何使用 webpack 优化资源
2017/10/20 Javascript
Es6 Generator函数详细解析
2018/02/24 Javascript
vue以组件或者插件的形式实现throttle或者debounce
2019/05/22 Javascript
js实现窗口全屏示例详解
2019/09/17 Javascript
微信小程序如何实现精确的日期时间选择器
2020/01/21 Javascript
vue开发中遇到的问题总结
2020/04/07 Javascript
vue实现循环滚动列表
2020/06/30 Javascript
jQuery实现评论模块
2020/08/19 jQuery
理解python正则表达式
2016/01/15 Python
python基础之入门必看操作
2017/07/26 Python
浅谈python 线程池threadpool之实现
2017/11/17 Python
Django组件之cookie与session的使用方法
2019/01/10 Python
Python如何将将模块分割成多个文件
2020/08/04 Python
汇智创新科技发展有限公司
2015/12/06 面试题
使用索引(Index)有哪些需要考虑的因素
2016/10/19 面试题
《问银河》教学反思
2014/02/19 职场文书
关于孝道的演讲稿
2014/05/21 职场文书
电子工程求职信
2014/07/17 职场文书
中国梦演讲稿范文
2014/08/28 职场文书
六查六看六改心得体会
2014/10/14 职场文书
国际最新研究在陨石中发现DNA主要成分 或由陨石带来地球
2022/04/29 数码科技