瞬间让SignalR 实现在线聊天室~

ASP.NET SignalR 是为 ASP.NET 开发人员提供的一个库,可以简化开发人员将实时 Web 功能添加到应用程序的过程。实时 Web 功能是指这样一种功能:当所连接的客户端变得可用时服务器代码可以立即向其推送内容,而不是让服务器等待客户端请求新的数据。

直接看效果图:

实现过程如下:

新建一个Hub类

完整代码:

Startup

using Microsoft.Owin;
using Owin;
[assembly: OwinStartupAttribute(typeof(Net.Ulon.SignalR.Startup))]
namespace Net.Ulon.SignalR
{
    public partial class Startup
    {
        public void Configuration(IAppBuilder app)
        {
            app.MapSignalR();
        }
    }
}

HubCS

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using Microsoft.AspNet.SignalR;
using System.Threading.Tasks;
using System.Threading;
using Microsoft.AspNet.SignalR.Hubs;
namespace Net.Ulon.SignalR.Hub
{
    /// <summary>
    /// HubName不填写即为类名称
    /// </summary>
    [HubName("Chat")]
    public class ChatHub : Microsoft.AspNet.SignalR.Hub
    {
        /// <summary>
        /// 获取当前客户端ID
        /// </summary>
        public string _clientID { get { return Context.ConnectionId; } }
        /// <summary>
        /// 获取当前时间
        /// </summary>
        private string _now { get { return DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss fff"); } }
        /// <summary>
        /// 获取消息
        /// </summary>
        private string GetMsg(string msg)
        {
            return string.Format("{0} : {1}", _now, msg);
        }
        /// <summary>
        /// 获取喊话
        /// </summary>
        private string GetSay(string say)
        {
            return string.Format("{0} :【{1}】 {2}", _now, _clientID, say);
        }
        public void Send(string msg)
        {
            //发送消息给其他客户端
            Clients.All.onMsg(_clientID, this.GetSay(msg));
            //发送消息给当前客户端
            Clients.Caller.onMsg(_clientID, this.GetMsg("消息发送成功~"));
            //Clients.Client(_clientID).onMsg(id, "Client Connect");
        }
        /// <summary>
        /// 连接
        /// </summary>
        /// <returns></returns>
        public override Task OnConnected()
        {
            Clients.Caller.onMsg(_clientID, this.GetMsg("连接服务器~"));
            Clients.AllExcept(_clientID).onMsg(_clientID, this.GetSay("闪耀登场~"));
            return base.OnConnected();
        }
        /// <summary>
        /// 断开
        /// </summary>
        /// <returns></returns>
        public override Task OnDisconnected(bool stopCalled)
        {
            Clients.Caller.onMsg(_clientID, this.GetMsg("连接断开~"));
            Clients.AllExcept(_clientID).onMsg(_clientID, this.GetSay("潇洒离去~"));
            return base.OnDisconnected(stopCalled);
        }
        /// <summary>
        /// 重新连接
        /// </summary>
        /// <returns></returns>
        public override Task OnReconnected()
        {
            Clients.Caller.onMsg(_clientID, this.GetMsg("重新连接服务器~"));
            Clients.AllExcept(_clientID).onMsg(_clientID, this.GetSay("重出江湖~"));
            return base.OnReconnected();
        }
    }
}  

ViewHtml

@{
    ViewBag.Title = "Home Page";
}
@section scripts{
    <script src="~/Scripts/jquery-1.10.2.min.js"></script>
    <script src="/Scripts/jquery.signalR-2.2.0.min.js"></script>
    <script src="~/signalr/hubs"></script>
    <script type="text/javascript">
        $(function () {
            var chat = $.connection.Chat;
            registerClientMethods(chat);
            $.connection.hub.start().done(function () {
                registerEvents(chat);
            });
            //注册客户端事件
            function registerEvents(chat) {
                $("#send").click(function () {
                    chat.server.send($("#msg").val());
                });
            }
            //注册客户端方法
            function registerClientMethods(chat) {
                chat.client.onMsg = function (id, text) {
                    $("#record").append("<div>" + text + "</div>");
                }
            }
        });
    </script>
}
<div>hello world~</div>
<div>
    <input type="text" id="msg" />
    <br />
    <input type="button" id="send" value="发送消息" />
</div>
<div id="record"></div>  

主要的功能就是 服务端推送消息/客户端发送消息

服务端推送消息

onMsg 是自定义的消息方法(客户端JS):

             chat.client.onMsg = function (id, text) {
                    $("#record").append("<div>" + text + "</div>");
                }

1.发送给所有客户端

Clients.All.onMsg

2.发送给单一客户端

Clients.Client(_clientID).onMsg

3.发送给其他客户端

Clients.AllExcept(_clientID).onMsg

Clients.Ohther.onMsg

4.发送给当前客户端

Clients.Caller.onMsg

除了上面的单一的还有Group 和 User

客户端发送消息

                $("#send").click(function () {
                    chat.server.send($("#msg").val());
                });

客户端发送下到服务端就是通过调用server,其中send是服务端定义的方法:

        public void Send(string msg)
        {
            //发送消息给其他客户端
            Clients.All.onMsg(_clientID, this.GetSay(msg));

            //发送消息给当前客户端
            Clients.Caller.onMsg(_clientID, this.GetMsg("消息发送成功~"));
            //Clients.Client(_clientID).onMsg(id, "Client Connect");
        }  
时间: 2024-10-11 16:11:35

瞬间让SignalR 实现在线聊天室~的相关文章

SignalR实现在线聊天室功能(欢迎、发送、回复、私信、屏蔽)

一.在线聊天室 1.新建解决方案 SignalROnlineChatDemo 2.新建MVC项目 SignalROnlineChatDemo.Web (无身份验证) 3.安装SignalR PM> install-package Microsoft.AspNet.SignalR 4. 创建一个称为 Startup.cs 的新类 1 public class Startup 2 { 3 public void Configuration(IAppBuilder app) 4 { 5 // 有关如何

Asp.NET MVC 使用 SignalR 实现推送功能二(Hubs 在线聊天室 获取保存用户信息)

简单介绍 关于SignalR的简单实用 请参考 Asp.NET MVC 使用 SignalR 实现推送功能一(Hubs 在线聊天室) 在上一篇中,我们只是介绍了简单的消息推送,今天我们来修改一下,实现保存消息,历史消息和用户在线 由于,我这是在一个项目([无私分享:从入门到精通ASP.NET MVC]从0开始,一起搭框架.做项目 目录索引)的基础上做的,所以使用到的一些借口和数据表,不详细解析,只是介绍一下思路和实现方式,供大家参考 用户登录注册信息 当用户登录之后,我们注册一下用户的信息,我们

基于Server-Sent Event的简单聊天室 Web 2.0时代,即时通信已经成为必不可少的网站功能,那实现Web即时通信的机制有哪些呢?在这门项目课中我们将一一介绍。最后我们将会实现一个基于Server-Sent Event和Flask简单的在线聊天室。

基于Server-Sent Event的简单聊天室 Web 2.0时代,即时通信已经成为必不可少的网站功能,那实现Web即时通信的机制有哪些呢?在这门项目课中我们将一一介绍.最后我们将会实现一个基于Server-Sent Event和Flask简单的在线聊天室.

基于Server-Sent Event的简单在线聊天室

一.Web即时通信 所谓Web即时通信,就是说我们可以通过一种机制在网页上立即通知用户一件事情的发生,是不需要用户刷新网页的.Web即时通信的用途有很多,比如实时聊天,即时推送等.如当我们在登陆浏览知乎时如果有人回答了我们的问题,知乎就会即时提醒我们,再比如现在电子商务的在线客服功能.这些能大大提高用户体验的功能都是基于Web即时通信实现的. 普通HTTP流程 客户端从服务器端请求网页 服务器作出相应的反应 服务器返回相应到客户端 而由于HTTP请求是无状态的,也就是说每次请求完成后,HTTP链

Node.js+socket.io在线聊天室

Node.js+socket.io实现在线聊天室,照着这个教程做的,稍加改动即可实现. Node.js:0.10.31 Express:3.* 创建工程chat: 添加几个文件,工程结构如下 代码: package.json: { "name": "application-name", "version": "0.0.1", "private": true, "scripts": { &

django+ajax实现在线聊天室

django+ajax实现在线聊天室 小项目中的一个,就是简单的聊天室 需求: 注册登陆之后才能发言 初始在聊天框中展示最近的消息 发送消息使用ajax,在后台完成消息的存储 使用轮循不断请求get新消息展示在聊天框中 Models 设计聊天消息主题的结构: class Chat(models.Model): sender = models.ForeignKey(User, related_name='has_chats') content = models.TextField() time =

Socket.io在线聊天室

从零开始nodejs系列文章,将介绍如何利Javascript做为服务端脚本,通过Nodejs框架web开发.Nodejs框架是基于V8的引擎,是目前速度最快的Javascript引擎.chrome浏览器就基于V8,同时打开20-30个网页都很流畅.Nodejs标准的web开发框架Express,可以帮助我们迅速建立web站点,比起PHP的开发效率更高,而且学习曲线更低.非常适合小型网站,个性化网站,我们自己的Geek网站!! 关于作者 张丹(Conan), 程序员Java,R,PHP,Java

Ajax PHP JavaScript MySQL实现简易的无刷新在线聊天室

思路 消息显示区 发消息 板块 消息显示 消息发送 优化 显示非重复性的数据 优化显示 加上滚动条 每次都显示最新消息 完整代码 前端代码 数据库表结构 服务器端代码 总结与展望 总结 展望 为更好的运用这两天学到的Ajax的相关的知识,就做了个简单的在线网络聊天室. 思路 实现聊天室,基本上就是通过Ajax来传递数据,让PHP来实现对数据的差入和查找,再交给前端JavaScript实现页面的更新,达到即时聊天的功能. 消息显示区 消息显示区就是一个DIV块,我们会借助Ajax获取到服务器端信息

在线聊天室的实现(2)--基于Netty 4.x的Echo服务器实现

前言: 就如前文所讲述的, 聊天室往往是最基本的网络编程的学习案例. 本文以WebSocket为底层协议, 实现一个简单的基于web客户端的Echo服务. 服务器采用Netty 4.x来实现, 源于其对websocket的超强支持, 基于卓越的性能和稳定. 本系列的文章链接如下: 1). websocket协议和javascript版的api 要点提示: Netty作为高性能网络编程框架, 其所有的网络IO操作皆为异步方式驱动. 而其核心的概念之一: ChannelHandler. 由一组Cha