一、首先,在MVC项目中安装SingalR包(SingalR2.0需要.net4.5以上,VS2010可以安装1.1.3版本,本例为VS2010+SignalR1.1.3)。

打开工具—NuGet程序管理器—程序包管理器控制台,输入:

Install-Package Microsoft.AspNet.SignalR-Version 1.1.3

安装完成后,一定要阅读弹出的txt,这里非常重要,

有两个很重要的提示,一是在Global.asax文件中加入RouteTable.Routes.MapHubs();二是在页面前端加入脚本<scriptsrc="~/signalr/hubs"></script>(注:本示例采用的是MVC4,MVC其他版本有其他的写法,所以要读这个readme)。

二、安装完signalr包后,我们在项目中添加一个Home控制器以及它的View,View选择母版页,记得在这个页面里加上

<scriptsrc="~/signalr/hubs"></script>

<script src="../../Scripts/jQuery.signalR-1.1.4.min.js"type="text/JavaScript"></script>

然后在项目中创建一个目录,目录里创建Hub类文件:

public class WorkflowHub: Hub

{

/// <summary>

/// 静态用户列表

/// </summary>

private IList<string> userList = UserInfo.userList;

/// <summary>

/// 用户的connectionID与用户名对照表

/// </summary>

private readonly static Dictionary<string, string>_connections = new Dictionary<string, string>();

/// <summary>

/// 发送函数,前端触发该函数给服务器,服务器在将消息发送给前端,(Clients.All.(函数名)是全体广播,另外Clients提供了组播,广播排除,组播排除,指定用户播发等等)

/// 该函数名在前端使用时一定要注意,前端调用该函数时,函数首字母一定要小写

/// </summary>

/// <param name="name1">发起者</param>

/// <param name="name2">消息接收者</param>

public voidSendByGroup(string name1, string name2)

{

//Client内为用户的id,是唯一的,SendMessage函数是前端函数,意思是服务器将该消息推送至前端

Clients.Client(_connections[name2]).SendMessage("来自用户"+name1 + " " + DateTime.Now.ToString("yyyy/MM/ddhh:mm:ss")+"的消息推送!");

}

/// <summary>

/// 用户上线函数

/// </summary>

/// <param name="name"></param>

public voidSendLogin(string name)

{

if (!userList.Contains(name))

{

userList.Add(name);

//这里便是将用户id和姓名联系起来

_connections.Add(name, Context.ConnectionId);

}

else

{

//每次登陆id会发生变化

_connections[name] = Context.ConnectionId;

}

//新用户上线,服务器广播该用户名

Clients.All.loginUser(userList);

}

}

其中

public class UserInfo

{

public static IList<string>userList = new List<string>();

}

为用户名称列表

在Home的View中,Index.cshtml:

<script src="../../Scripts/jquery.signalR-1.1.4.min.js"type="text/javascript"></script>

<!--Reference the autogenerated SignalR hub script. 注意一定别忘记写这句,signalr生成的脚本都在这-->

<script src="~/signalr/hubs"></script>

<h1>流程演示</h1>

<input type="hidden" id="displayname" />

<h2 id="thisname"></h2><br />

<select id="username" style="width:153px;">

</select>

<input id="send" type="button" value="发送" />

<div>

<h1 id="messgae"></h1>

</div>

<script type="text/javascript">

$(function () {

//前端Hub的使用,注意的是,Hub的名字是WorkflowHub,这里使用时首字母小写

var work = $.connection.workflowHub;

$('#displayname').val(prompt('请输入昵称:', ''));

$('#thisname').text('当前用户:'+$('#displayname').val());

//对应后端的SendMessage函数,消息接收函数

work.client.sendMessage = function(message) {

$('#messgae').append(message + '</br>')

};

//后端SendLogin调用后,产生的loginUser回调

work.client.loginUser = function(userlist) {

reloadUser(userlist);

};

//hub连接开启

$.connection.hub.start().done(function () {

var username = $('#displayname').val();

//发送上线信息

work.server.sendLogin(username);

//点击按钮,发送消息

$('#send').click(function() {

var friend = $('#username').val();

//调用后端函数,发送指定消息

work.server.sendByGroup(username, friend);

});

});

});

//重新加载用户列表

var reloadUser = function(userlist) {

$("#username").empty();

for (i = 0;i < userlist.length; i++) {

$("#username").append("<option value="+userlist[i]+">"+userlist[i]+"</option>");

}

}

</script>

调试执行,打开两个网页(如果提示signalr必须在jquery之后,就在_layout.cshtml中把jquery放前面),输入用户名称,登录后在列表中会显示当前登录的用户的信息:

另一个网页中输入李晨:

我们在李晨这里,给邓超发送,这样我们就会在邓超这里看到推送的消息了:

SignalR指定用户推送消息的更多相关文章

  1. 微信硬件平台(八) 4 ESP8266通过微信公众号给用户推送消息

    https://api.weixin.qq.com/cgi-bin/message/custom/send?access_token=自己申请微信公众号的TOKEN 输出结果:  由于aRDUINO串 ...

  2. JAVA调用易信接口向指定好友推送消息(二)POST测试

    易信的API接口做的还算简单 http://open.yixin.im/document/oauth/api 根据指南上的步骤,利用易信提供的测试ID AppID(client_id): yxbbd0 ...

  3. SignalR控制台自托管服务端向web客户端指定用户推送数据,客户端断线重连

    一.前言 SignalR是微软推出的开源实时通信框架.其内部使用Web Socket, Server Sent Events 和 Long Polling作为底层传输方式,SignalR会根据客户端和 ...

  4. PHP利用模板消息无限制向用户推送消息

    <?php //获取微信access_token function getaccess_token(){ //appid与appsecret改成你自己的 $appid = '自己的appid'; ...

  5. JAVA调用易信接口向指定好友推送消息(一)背景需求

    众所周知,中国电信内部一直使用易信群进行交流 各种工作交流都在易信群里面沟通 包括投诉处理,障碍报修,拍照上传 最重要的就是每天甚至每个时点的指标完成情况的通报 所以只能用4个字来形容 String ...

  6. signalr推送消息

    参考:Tutorial: Getting Started with SignalR 2 and MVC 5 环境:vs2013,webapi2,entity framework6.0 实现效果:当用户 ...

  7. java-给微信推送消息 利用企业微信

    目的:给关注用户推送消息 场景:自动化测试,运维监控,接口访问等报错预警.例如线上接口报错,发送提醒消息 准备工作: 1:注册企业号(为什么不用公众号呢?) 企业号注册 2:常用参数介绍: 1:COR ...

  8. 使用极光推送(www.jpush.cn)向安卓手机推送消息【服务端向客户端主送推送】C#语言

    在VisualStudio2010中新建网站JPushAndroid.添加引用json帮助类库Newtonsoft.Json.dll. 在web.config增加appkey和mastersecret ...

  9. Qt通过极光推送向app推送消息

    简介 最近在做个项目,当客服端收到防盗的消息通知时向手机app推送一个消息,告知有防盗报警.这么小的功能没必要自己写个推送端,极光推送免费而且推送的成功率高,已经能满足我们的需求了. 极光推送的文档大 ...

随机推荐

  1. Raft 实现日志复制同步

    Raft 实现日志复制同步 本篇文章以 John Ousterhout(斯坦福大学教授) 和 Diego Ongaro(斯坦福大学获得博士学位,Raft算法发明人) 在 Youtube 上的讲解视频及 ...

  2. arm交叉编译器科普

    交叉编译工具链的命名规则为:arch [-vendor] [-os] [-(gnu)eabi] arch - 体系架构,如ARM,MIPS vendor - 工具链提供商 os - 目标操作系统 ea ...

  3. c#中读取数据库bit布尔字段数据转换Int和bool时的错误

    数据库里bit这个布尔类型的字段,非常实用,但是在c#里读取时,许多人喜欢犯一些错误,导致运行报错. 实际中,有效的正确读取方法只有以下两种: int xxx= Convet.ToInt16(read ...

  4. react-router3.x hashHistory render两次的bug,及解决方案

    先写一个简单App页面,其实就是简单修改了react-router的官方例子中的animations例子,修改了两个地方: 1.路由方式由browserHistory修改为hashHistory 2. ...

  5. Gulp自动构建Web前端程序

    这两天在一个朋友在项目上碰到了一个这样的问题,在运营过程中,用户在浏览器上对某个表单进行数据提交时,需要引入新的平台接口数据的业务,通过评估,开发团队马上修改了相关后台代码和部分的前端脚本代码,通过简 ...

  6. C#开发人员应该知道的13件事情

    本文讲述了C#开发人员应该了解到的13件事情,希望对C#开发人员有所帮助. 1. 开发过程 开发过程是错误和缺陷开始的地方.使用工具可以帮助你在发布之后,解决掉一些问题. 编码标准 遵照编码标准可以编 ...

  7. Myeclipse 搭建Java Web 项目 《一》

    今天将图文并茂的介绍如何使用myclipse 创建Java Web 项目;我使用的是myclipse 8.6 来进行创建: 1.打开Myeclipse,点击File --->然后New ---- ...

  8. 纪中集训 Day 6

    今天他们回去了,就剩我和DWJ(一位初三大大(后来问云神才知道的ORZ))一起在做题,不得不说他真的是太厉害了,一个升初三大大在各种方面都比我强QAQ 让我突然感觉到自己的高一还是不够努力啊QAQ 连 ...

  9. 从0移植uboot (二) _启动流程分析

    经过了上一篇的配置,我们已经执行make就可以编译出一个uboot.bin,但这还不够,首先,此时的uboot并不符合三星芯片对bootloader的格式要求,其次,此时的uboot.bin也没有结合 ...

  10. EFcore与动态模型

    在开发商城系统的时候,大家会遇到这样的需求,商城系统里支持多种商品类型,比如衣服,手机,首饰等,每一种产品类型都有自己独有的参数信息,比如衣服有颜色,首饰有材质等,大家可以上淘宝看一下就明白了.现在的 ...