前一段时间写了几篇关于signalr的文章

1.MVC中使用signalR入门教程

2.mvc中signalr实现一对一的聊天

3.Xamarin
android中使用signalr实现即时通讯

在平时的工作中用到了signalr进行消息的推送,所以总结了这几篇文章,今天我就来写一写这个signalr如何使用Group 分组方法群发消息。更全面地了解和学习使用signalr。

在开始学习Signalr Group群发消息之前我们来看一下所实现的效果图:

强大的signalr已经封装好了Group方法,已经在Hub里面集成了Groups分组管理,关键的使用方法如下:

//加入Group组方法
//Context.ConnectionId 连接ID,每个页面连接集线器即会产生唯一ID
//roomName分组的名称
Groups.Add(Context.ConnectionId, roomName); //移除Group组
Groups.Remove(Context.ConnectionId, roomName); //作用:调用分组内连接对象,注册客户端Js方法
//Room:分组名称
//new string[0]:过滤(不发送)的连接ID数组
// msg:消息内容
 Clients.Group(Room, new string[0]).sendMsg(Room,msg)

在客户端中调用:
chat.client.sendMsg=function(Room,msg){}

当然在实际中如何实现,看下接下来的代码

namespace signalrGroupDemo.Models
{
public class DbContext
{
public DbContext()
{
Users = new List<User>();
Connections = new List<Connection>();
Rooms = new List<Room>();
}
//用户集合
public List<User> Users { get; set; } //连接集合
public List<Connection> Connections { get; set; } //房间集合
public List<Room> Rooms { get; set; }
}
//用户类
public class User
{
[Key]
public string UserName { get; set; }
//用户连接
public List<Connection> Connections { get; set; }
//用户房间集合
public virtual List<Room> Rooms { get; set; }
public User()
{
Connections = new List<Connection>();
Rooms = new List<Room>();
}
}
public class Connection
{
//连接ID
public string ConnectionID { get; set; }
//用户代理
public string userAgent { get; set; }
//是否连接
public bool Connected { get; set; }
}
//房间类
public class Room
{
[Key]
public string RommName { get; set; }
//用户集合
public virtual List<User> Users { get; set; }
public Room() {
Users = new List<User>();
}
}
}

第二步:引入Signalr类库,添加Hub集线器类

using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using System.Web;
using Microsoft.AspNet.SignalR;
using signalrGroupDemo.Models;
using Newtonsoft.Json;
using Microsoft.AspNet.SignalR.Hubs; namespace signalrGroupDemo
{
[HubName("groupHub")]
public class GroupHUb : Hub
{
public void Hello()
{
Clients.All.hello();
}
public static DbContext db = new DbContext();
/// <summary>
/// 重写Hub连接事件
/// </summary>
/// <returns></returns>
public override Task OnConnected()
{
//查询用户
var user = db.Users.Where(w => w.UserName == Context.ConnectionId).FirstOrDefault();
//判断用户是否存在
if (user == null)
{
user = new User()
{
UserName = Context.ConnectionId
};
db.Users.Add(user);
}
//发送房间列表
var rooms = db.Rooms.Select(p => p.RoomName).ToList();
//注册getRooms 获取房间的方法
Clients.Client(Context.ConnectionId).getRoomList(JsonConvert.SerializeObject(rooms));
return base.OnConnected();
}
//更新所有用户的房间列表
private void GetRooms()
{
var rooms =JsonConvert.SerializeObject(db.Rooms.Select(p => p.RoomName).ToList());
Clients.All.getRoomList(rooms);
} //重写Hub链接断开事件
public override Task OnDisconnected(bool s)
{
var user = db.Users.Where(u=>u.UserName==Context.ConnectionId).FirstOrDefault();
//判断用户是否存在,存在则删除
if (user != null)
{
//删除用户
db.Users.Remove(user); }
return base.OnDisconnected(s);
}
//加入聊天室
public void AddRoom(string roomName)
{
//查询聊天室
var room = db.Rooms.Find(a=>a.RoomName==roomName);
//存在则加入
if (room != null)
{
//查找房间中是否存在此用户
var isUser = room.Users.Where(w => w.UserName == Context.ConnectionId).FirstOrDefault();
//不存在则加入
if (isUser == null)
{
var user = db.Users.Find(a => a.UserName == Context.ConnectionId);
user.Rooms.Add(room);
room.Users.Add(user);
Groups.Add(Context.ConnectionId, roomName);
//注册加入聊天室的addRoom方法
Clients.Client(Context.ConnectionId).addRoom(roomName);
}
else
{
Clients.Client(Context.ConnectionId).showMessage("请勿重复加入房间");
}
}
}
//创建聊天室
public void CreateRoom(string roomName)
{
var room = db.Rooms.Find(a=>a.RoomName==roomName);
if (room == null)
{
Room r = new Room() { RoomName = roomName };
//将房间加入列表
db.Rooms.Add(r);
AddRoom(roomName);
Clients.Client(Context.ConnectionId).showMessage("房间创建完成");
GetRooms();
}
else
{
Clients.Client(Context.ConnectionId).showMessage("房间名重复");
}
}
//退出聊天室
public void ExitRoom(string roomName)
{
//查找房间是否存在
var room = db.Rooms.Find(a=>a.RoomName==roomName);
//存在则删除
if (room != null)
{
//查找要删除的用户
var user = room.Users.Where(p => p.UserName == Context.ConnectionId).FirstOrDefault();
//移除此用户
room.Users.Remove(user);
//如果房间人数为0,怎删除房间
if (room.Users.Count == 0)
{
db.Rooms.Remove(room);
}
//Groups Remove移除分组方法
Groups.Remove(Context.ConnectionId,roomName);
//提示客户端
Clients.Client(Context.ConnectionId).removeRoom("退出成功");
}
}
//给分组内所有用户发送消息
public void SendMsg(string Room,string Message)
{
Clients.Group(Room, new string[0]).sendMessage(Room,Message+" "+DateTime.Now.ToString());
}
}
}

第三步:前端调用注册的Server方法和注册Client方法

@{
Layout = null;
}
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>signalr group 分组方法的使用</title>
<script src="~/Scripts/jquery-1.10.2.min.js"></script>
<script src="~/Scripts/jquery.signalR-2.2.1.min.js"></script>
@*这里是虚拟目录,也就是你再OWIN Startup中注册的地址*@
<script src="~/signalr/hubs"></script>
</head>
<body>
<div><div>名称:<p id="userName"></p></div>
房间名:<input type="text" value="ceshi" id="roomName"/>
<button id="createRoom">创建聊天室</button></div>
<div style="float:left;border:double">
<div>房间列表</div><ul id="roomList"></ul>
</div>
<div id="rooms"></div>
<script>
var chat;
var roomCount =0;
$(function(){
chat = $.connection.groupHub;
//调用hub中注册的showMessage方法
chat.client.showMessage= function (message)
{
alert(message);
}
//调用hub中注册的sendMessage 方法
chat.client.sendMessage= function (roomname, message)
{
debugger
$("#" + roomname).find("ul").each(function () {
$(this).append('<li>'+message+'</li>');
})
}
//调用hub中removeRoom 退出房间方法
chat.client.removeRoom = function (data)
{
alert(data);
}
//注册查询房间列表的方法
chat.client.getRoomList = function (data) { if (data) {
debugger
var jsonData = $.parseJSON(data);
$("#roomList").html(" ");
for (var i = 0; i < jsonData.length; i++) {
var html = '<li>房间名:' + jsonData[i] + '<button roomName="' + jsonData[i] + '" onclick="addRoom(this)">加入</button> </li>'
$("#roomList").append(html);
}
}
}
//调用hub中addRoom 加入房间的方法
chat.client.addRoom = function (roomName)
{
var html = '<div style="float:left; margin-left:30px; border:double" id="' + roomName + '" roomname="' + roomName + '" ><button onclick="removeRoom(this)">退出房间</button> \
' + roomName + '房间聊天记录如下:<ul></ul> <input type="text"/> <button onclick="send(this)">发送</button><div>'
$("#rooms").append(html);
} //获取用户名称
$("#userName").html(prompt('请输入您的名称:', ''));
$.connection.hub.start().done(function () {
$("#createRoom").click(function ()
{
if (roomCount < 2) {
chat.server.createRoom($("#roomName").val());
}
else
{
alert("聊天窗口只允许有2个");
}
})
}) }) //发送消息的方法
function send(btn)
{ var message = $(btn).prev().val();
var room = $(btn).parent();
var userName = $("#userName").html();
message = userName + ":" + message;
var roomName = $(room).attr("roomName");
chat.server.sendMsg(roomName,message);
}
//退出房间
function removeRoom(btn)
{
var room = $(btn).parent();
var roomName = $(room).attr("roomName");
chat.server.exitRoom(roomName);
}
//加入房间
function addRoom(roomName)
{
var data = $(roomName).attr("roomName");
chat.server.addRoom(data);
} </script>
</body>
</html>


代码下载地址:作者:张林标题:signalr中Group 分组群发消息的简单使用 原文地址:http://blog.csdn.net/kebi007/article/details/54866672转载随意注明出处

signalr中Group 分组群发消息的简单使用的更多相关文章

  1. 浅析mongodb中group分组

    这篇文章主要介绍了浅析mongodb中group分组的实现方法及示例,非常的简单实用,有需要的小伙伴可以参考下. group做的聚合有些复杂.先选定分组所依据的键,此后MongoDB就会将集合依据选定 ...

  2. mongodb命令行group分组和java代码中group分组

    group分组统计是数据库比较常用的功能,mongodb也不例外.不过相对于普通的增删改查,group操作就略微麻烦一些, 这里对group在shell中的操作.使用java原生代码操作以及集成spr ...

  3. .net微信公众号开发——群发消息

    作者:王先荣    本文将介绍微信公众号开发中用于群发消息的类MassMessage,包括:(1)MassMessage类:(2)群发:(3)删除:(4)预览:(5)查询发送状态:(6)接收推送群发结 ...

  4. SignalR 中丰富多彩的消息推送方式

    在上一篇 SignalR 文章中,演示了如何通过 SignalR 实现了简单的聊天室功能:本着简洁就是美的原则,这一篇我们也来聊聊在 SignalR 中的用户和组的概念,理解这些基础知识有助于更好的开 ...

  5. 微信分组群发图文40152,微信分组群发图文invalid group id hint

    微信分组群发40152,微信分组群发invalid group id hint >>>>>>>>>>>>>>> ...

  6. java微信接口之五—消息分组群发

    一.微信消息分组群发接口简介 1.请求:该请求是使用post提交地址为: https://api.weixin.qq.com/cgi-bin/message/mass/sendall?access_t ...

  7. MongoDB学习笔记~管道中的分组实现group+distinct

    回到目录 mongoDB的管道是个好东西,它可以将很多操作批处理实现,即将多个命令放入一个管道,然后去顺序的执行它们,今天我要说的是,利用管道中的分组来实现实现中的ditinct+group的效果,即 ...

  8. C# 中正则表达式 Group 分组【转】

    http://www.cnblogs.com/kiant71/archive/2010/08/14/1799799.html 在一个正则表达式中,如果要提取出多个不同的部分(子表达式项),需要用到分组 ...

  9. C# 中正则表达式 Group 分组

    在一个正则表达式中,如果要提取出多个不同的部分(子表达式项),需要用到分组功能. 在 C# 正则表达式中,Regex 成员关系如下,其中 Group 是其分组处理类. Regex –> Matc ...

随机推荐

  1. LuaJavaBridge - Lua 与 Java 互操作的简单解决方案

    http://dualface.github.io/blog/2013/01/01/call-java-from-lua/ 最近在游戏里要集成中国移动的 SDK,而这些 SDK 都是用 Java 编写 ...

  2. SpringMVC中遇到页面跳转出现404错误的问题

    今天遇到了一个问题: 使用SpringMVC时,出现页面无法跳转的情况(404错误), 出现这个异常的原因在于SpringMVC的配置文件中控制器的配置书写错误: 原代码: <context:c ...

  3. 2723:不吉利日期-poj

    2723:不吉利日期 总时间限制:  1000ms 内存限制:  65536kB 描述 在国外,每月的13号和每周的星期5都是不吉利的.特别是当13号那天恰好是星期5时,更不吉利.已知某年的一月一日是 ...

  4. Geth控制台使用及Web3.js使用实战

    在开发以太坊去中心化应用,免不了和以太坊进行交互,那就离不开Web3. Geth 控制台(REPL)实现了所有的web3 API及Admin API, 使用好 Geth 就是必修课.结合Geth命令用 ...

  5. 浅谈IM(InstantMessaging) 即时通讯/实时传讯【理论篇】

        一.IM简要概述 IM InstantMessaging(即时通讯,实时传讯)的缩写是IM,互动百科大致解释是一种可以让使用者在网络上建立某种私人聊天(chatroom)的实时通讯服务. 大部 ...

  6. RFID电动自行车与共享单车之物联网比较

    目前比较热门的RFID电动自行车管理和共享单车,都是属于物联网范畴.它们之间有什么不同呢? 1.RFID电动自行车管理系统原理 RFID电动自行车管理,利用了有源RFID技术,使用基站SR8读取安装在 ...

  7. Django学习(1)一首情诗

    Django是Python中Web开发的最有代表性的框架之一.本文将简单介绍如何入门Django开发. 首先确保你的linux系统已安装django模块.打开Python3,利用以下命令可找到djan ...

  8. Ubuntu 16.04 安装wine QQ

    1.进入 http://www.ubuntukylin.com/application/show.php?lang=cn&id=279下载Wine QQ 2.解压压缩包 3.将文件夹中三个de ...

  9. Django中多表查询思路

    需求: 1.有一张文章表和一张评论表 2.两张表的关系是一对多 3.规则:若是有新评论,则将对应的文章置顶,若是有新文章则将新文章置顶. 思路: 在文章表中增加一个最后评论时间的字段.然后采用分组排序 ...

  10. JavaScript实现策略模式

    在开篇之前先分享今天看到的一句关于设计模式的话:将不变的部分和变化的部分隔开是每个设计模式的主题 请大家自行感受这句话的精髓所在,并且思考学习设计模式究竟能给我们编程带来什么样的东西,欢迎大家在文章下 ...