一步一步学习SignalR进行实时通信_6_案例
一步一步学习SignalR进行实时通信\_6_案例1
前言
由于这段时间在找房子,所以耽误了一段时间。前几讲把一些基础的东西稍微介绍了下,这一讲就简单介绍一个小例子,大致功能是实现在线聊天,并显示在线用户、用户上下线实时提醒。这个例子并不复杂只是把之前介绍联系起来。
在这里为了简单起见,暂时不涉及到数据库的操作。
类的定义
用户信息类UserInfo
public class UserInfo{/// <summary>/// ConnectionId/// </summary>public string ConnectionId { get; set; }/// <summary>/// 姓名/// </summary>public string Name { get; set; }/// <summary>/// 上线时间/// </summary>public DateTime ConnectedAt { get; set; }/// <summary>/// 在线标志/// </summary>public bool IsOnline { get; set; }}
各块功能
后台
上线
public override Task OnConnected(){Interlocked.Increment(ref _usersCount);var user = new UserInfo(){ConnectionId = Context.ConnectionId,IsOnline = true,Name = "user" + _usersCount,ConnectedAt = DateTime.Now};_users[Context.ConnectionId] = user;var notifyAll = (Task)Clients.All.NewUserNotification(user);var updateMessage = (Task)Clients.Caller.UpdateMessage(user.Name, _users.Values.ToArray());var sendToAll = (Task)Clients.Others.welcome(_users.Values.ToArray());return notifyAll.ContinueWith(_ => updateMessage).ContinueWith(_ => sendToAll);}
下线
public override Task OnDisconnected(){UserInfo user;if (_users.TryRemove(Context.ConnectionId, out user)){return Clients.All.UserDisconnectedNotification(user);}return base.OnDisconnected();}
修改昵称
public Task ChangeNickname(string newName){UserInfo user;if (_users.TryGetValue(Context.ConnectionId, out user)){var oldName = user.Name;user.Name = newName;return Clients.All.NicknameChangedNotification(user, oldName);}return null;}
发送消息给所有人
public Task Send(string message){UserInfo user;if (_users.TryGetValue(Context.ConnectionId, out user)){var msgToSend = string.Format("[{0}]: {1}", user.Name, message);return Clients.All.Message(msgToSend);}return null;}
前台
用户上线消息
function newUserNotification(user) {if (getUserElement(user.ConnectionId).length == 0) {$("#users").append($(getUserListItem(user)));}systemMessage("欢迎 " + user.Name + " 用户进入聊天室!");}
昵称改变消息
function nicknameChangedNotification(user, oldName) {var userElement = getUserElement(user.ConnectionId);if (userElement.length > 0) {userElement.replaceWith($(getUserListItem(user)));systemMessage(oldName + " 改名为 " + user.Name + ".");}if (user.Id === $.connection.hub.id) {$("#name").text(user.Name);}
用户下线消息
function userDisconnectedNotification(user) {var userElement = getUserElement(user.ConnectionId);if (userElement.length > 0) {systemMessage(user.Name + " 离开聊天室.");userElement.remove();}}
更新个人信息
function updateMessage(assignedNickname, userList) {var result = "";for (var i = 0; i < userList.length; i++) {var user = userList[i];result += getUserListItem(user);}$("#users").empty();$("#users").append(result);$("#username").text(assignedNickname);$("#user-info").show();}
用户上线提醒
function welcome(userList) {var result = "";for (var i = 0; i < userList.length; i++) {var user = userList[i];result += getUserListItem(user);}$("#users").empty();$("#users").append(result);}
发送消息
function message(message) {var $panel = $("#chatpanel");$panel.append("<li class='list-group-item'>" + message + "</li>");$panel.scrollTop($panel[0].scrollHeight);}
效果图

结束语
功能较为简单,本来还加了其他的功能,但是由于最近太忙了,打好了一半然后又全部删掉了,后面有时间再慢慢加上去。
本文发布至作业部落
参考文献
一步一步学习SignalR进行实时通信_6_案例的更多相关文章
- 一步一步学习SignalR进行实时通信_8_案例2
原文:一步一步学习SignalR进行实时通信_8_案例2 一步一步学习SignalR进行实时通信\_8_案例2 SignalR 一步一步学习SignalR进行实时通信_8_案例2 前言 配置Hub 建 ...
- 一步一步学习SignalR进行实时通信_1_简单介绍
一步一步学习SignalR进行实时通信\_1_简单介绍 SignalR 一步一步学习SignalR进行实时通信_1_简单介绍 前言 SignalR介绍 支持的平台 相关说明 OWIN 结束语 参考文献 ...
- 一步一步学习SignalR进行实时通信_9_托管在非Web应用程序
原文:一步一步学习SignalR进行实时通信_9_托管在非Web应用程序 一步一步学习SignalR进行实时通信\_9_托管在非Web应用程序 一步一步学习SignalR进行实时通信_9_托管在非We ...
- 一步一步学习SignalR进行实时通信_7_非代理
原文:一步一步学习SignalR进行实时通信_7_非代理 一步一步学习SignalR进行实时通信\_7_非代理 SignalR 一步一步学习SignalR进行实时通信_7_非代理 前言 代理与非代理 ...
- 一步一步学习SignalR进行实时通信_5_Hub
原文:一步一步学习SignalR进行实时通信_5_Hub 一步一步学习SignalR进行实时通信\_5_Hub SignalR 一步一步学习SignalR进行实时通信_5_Hub 前言 Hub命名规则 ...
- 一步一步学习SignalR进行实时通信_4_Hub
原文:一步一步学习SignalR进行实时通信_4_Hub 一步一步学习SignalR进行实时通信\_4_Hub SignalR 一步一步学习SignalR进行实时通信_4_Hub 前言 创建Hub 配 ...
- 一步一步学习SignalR进行实时通信_3_通过CORS解决跨域
原文:一步一步学习SignalR进行实时通信_3_通过CORS解决跨域 一步一步学习SignalR进行实时通信\_3_通过CORS解决跨域 SignalR 一步一步学习SignalR进行实时通信_3_ ...
- 一步一步学习SignalR进行实时通信_2_Persistent Connections
原文:一步一步学习SignalR进行实时通信_2_Persistent Connections 一步一步学习SignalR进行实时通信\_2_Persistent Connections Signal ...
- 12.Linux软件安装 (一步一步学习大数据系列之 Linux)
1.如何上传安装包到服务器 有三种方式: 1.1使用图形化工具,如: filezilla 如何使用FileZilla上传和下载文件 1.2使用 sftp 工具: 在 windows下使用CRT 软件 ...
随机推荐
- django接收和发送json数据
通过json.jumps处理字典数据, 发送给前端 def get_context_data(self, **kwargs): ctx = super(HelpUpdateView, self).ge ...
- UVA 120 Stacks of Flapjacks
每次从最底部开始处理,如果不是最大值,则把最大值翻到底部.这就是最优解.原理自己模拟一下就好... 注意半径不是从1开始.数据处理要仔细. #include <iostream> #inc ...
- sql server数据库实现保留指定位数小数的函数
有时候需要对一个特定的含有小数点的数字保留指定位数,比如"123.123600". 在数据库中以函数的形式实现如下: USE [数据库名称] GO /****** Object: ...
- MEMS陀螺仪(gyroscope)的工作原理
传统的陀螺仪主要是利用角动量守恒原理,因此它主要是一个不停转动的物体,它的转轴指向不随承载它的支架的旋转而变化. 但是MEMS陀螺仪(gyroscope)的工作原理不是这样的,因为要用微机械技术在硅片 ...
- index seek与index scan
原文地址:http://blog.csdn.net/pumaadamsjack/article/details/6597357 低效Index Scan(索引扫描):就全扫描索引(包括根页,中间页和叶 ...
- Nim游戏博弈
Nim游戏的概述: 还记得这个游戏吗? 给出n列珍珠,两人轮流取珍珠,每次在某一列中取至少1颗珍珠,但不能在两列中取.最后拿光珍珠的人输. 后来,在一份资料上看到,这种游戏称为"拈(Nim) ...
- cocos2dx lua 学习笔记(一)
macosx 安装 lua curl -R -O http://www.lua.org/ftp/lua-5.1.4.tar.gz tar zxf lua-5.1.4.tar.gz cd lua-5.1 ...
- 网站服务管理系统wdcp简介及功能特性
WDCP是WDlinux Control Panel的简称,是一套用PHP开发的Linux服务器管理系统以及虚拟主机管理系统,,旨在易于使用Linux系统做为我们的网站服务器,以及平时对Linux服务 ...
- TagBuilder 性能如此低下?
本文来自:http://www.cnblogs.com/zhuisha/archive/2010/03/12/1684022.html 需要通过ASP.NET MVC生成一个列表,MVC里面根正苗红的 ...
- 依赖注入及AOP简述(七)——FQCN请求模式
2.2. FQCN请求模式 为了弥补纯字符串请求模式中的类型安全问题,全类名(FQCN)请求模式就应运而生了.其思想便是,在向容器请求依赖对象的时候,不是通过字符串的标识符.而是通过被请求的依赖 ...