用SignaiR和Push.js完成消息推送代码详解


本文摘自PHP中文网,作者Y2J,侵删。

ASP.NET SignalR 是为 ASP.NET 开发人员提供的一个库,可以简化开发人员将实时 Web 功能添加到应用程序的过程。有兴趣的可以了解一下。

一.使用背景

1. SignalR是什么?

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

2.Push.js是什么?【需要浏览器支持H5Notifications】

Notifications翻译过来即是通知。那么Push.js的通知又是什么样的,见下图:大多数在屏幕的右下角出现。

需要允许哦:

3.很多时候我们只能使用轮询的方式进行数据展示的更新和消息推送。于是就想到有没有一种方式可以完成服务端数据更新时同步更新客户端的一种解决方案。

二.开始部署一个 SignalR项目【使用mvc】

1.新建mvc项目

.....................

2.导入程序包【Vs2015】

工具->NuGet包管理器-> 程序包管理控制台->Install-Package Microsoft.AspNet.SignalR->等待安装成功

3.新建集线器类

项目->右键->添加->新建项->SignalR->SignalR 永久链接类->保存->【以MyConnection1为例】MyConnection1

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

public class MyConnection1 : PersistentConnection

 {

   /// <summary>

   /// 发送消息

   /// </summary>

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

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

   /// <returns></returns>

   protected override Task OnConnected(IRequest request, string connectionId)

   {

     Debug.WriteLine(connectionId);

     return Connection.Send(connectionId, "Welcome!");//单推事列

   }

 

   /// <summary>

   /// 接受客户端消息

   /// </summary>

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

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

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

   /// <returns></returns>

   protected override Task OnReceived(IRequest request, string connectionId, string data)

   {

     Debug.WriteLine(data);

     return Connection.Broadcast(data);//广播

   }

   /// <summary>

   /// 掉线

   /// </summary>

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

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

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

   /// <returns></returns>

   protected override Task OnDisconnected(IRequest request, string connectionId, bool stopCalled)

   {

     Debug.WriteLine("掉线");

     return base.OnDisconnected(request, connectionId, stopCalled);

   }

 

   /// <summary>

   /// 重连

   /// </summary>

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

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

   /// <returns></returns>

   protected override Task OnReconnected(IRequest request, string connectionId)

   {

     Debug.WriteLine("重连");

     return base.OnReconnected(request, connectionId);

   }

 }

4.新建 Owin Startup 类【SignalR遵循Owin标准,Startup则是组件的启动,默认会存在Startup类,只需修改即可】

我们在Configuration里面追加以下代码

1

2

3

4

public void Configuration(IAppBuilder app)

    {

      app.MapSignalR<MyConnection1>("/myconnection");

    }

解释:访问myconnection的时候,触发MyConnection1

5.增加客户端【h5】

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

@{

  ViewBag.Title = "Home Page";

  Layout = null;

}

<!DOCTYPE html>

<html>

<head>

  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

  <title></title>

  <meta charset="utf-8" />

</head>

<body>

  <script src="~/Scripts/jquery-1.10.2.js"></script>

  <script src="~/Scripts/jquery.signalR-2.2.1.js"></script>

  <script type="text/javascript">

    var conn = $.connection("/myconnection");

 

    conn.start().done(function (data) {

      console.log("已连接服务器,当前GUID为" + data.id);

      conn.send("To Admin");//发送给服务器

    });

 

    //接受服务器的推送

    conn.received(function (data) {

      console.log("服务器返回消息: " + data);

    });

  </script>

</body>

</html>

6.启动项目 打开浏览器控制台,你会发现见下图、这就表示你已经完成了第一步。

7.下面我们需要准备 push.js

下载地址 github.com/Nickersoft/push.js

8.引用js

1

<script src="../Js/push.js"></script>

9.新建js推送demo

1

2

3

4

5

6

7

8

9

10

11

12

13

function push(data, url, img) {

  var imgurl = img != "" ? img : "../Images/icon.png";

  Push.create("新通知", {

    body: data,

    icon: imgurl,

    requireInteraction: true,

    onClick: function () {

      window.focus();

      this.close();

      window.location.href =url;

    }

  });

}

解释:data:为消息内容

url:为点击通知进入的链接

img: 为通知展示的图片地址

requireInteraction: 设置为true时,除非用户手动关闭或单击该通知,否则该通知不会关闭。需要设置消失时间请替换该属性为timeout: 5000 单位毫秒

其他事件请阅读:www.npmjs.com/package/push.js

10.组合两者

1

2

3

4

5

6

7

8

9

10

11

12

13

14

//实时推送

var conn = $.connection("/myconnection");

 

conn.start().done(function (data) {

  console.log("已连接服务器,当前GUID为" + data.id);

});

 

//接受服务器的推送

conn.received(function (msg) {

  console.log("服务器返回消息: " + msg);

  if (msg != "") {

    push(msg, "#", "")

  }

});

11.效果如下:

12.实现服务器的主动推送.现只介绍广播。单推原理一致。

分为广播及单推两种模式。

广播:

1

2

var context = GlobalHost.ConnectionManager.GetConnectionContext<MyConnection1>();//获取你当前的Connection连接

 context.Connection.Broadcast("我是一条新的推送消息!");//广播推送

单推:

1

2

var context = GlobalHost.ConnectionManager.GetConnectionContext<MyConnection1>();//获取你当前的Connection连接

context.Connection.Send(connectionId, "Welcome!");//单推事列

connectionId:是服务端为每个客户端分配的GUID

13.效果如下:

这样当我们服务端处理某个任务时就可以调用广播来实现主动推送到客户端,进行数据的即时更新及消息的推送。

【相关推荐】

1. ASP免费视频教程

2. ASP教程

3. 李炎恢ASP基础视频教程

以上就是用SignaiR和Push.js完成消息推送代码详解的详细内容!

相关阅读 >>

什么是asp.net core?介绍asp.net core的优势

关于asp.net core网站在docker中运行的详解

分享asp.net学习笔记(9)webpages图表

asp.net之exceptionfilter过滤器

关于asp.net视频教程的资源分享

web api的 asp.net属性路由实例详解

webclient上传图片到远程服务的代码示例

有关asp.net中config文件的读写讲解

asp.net中的参数与特殊类型的实例详解

asp.net是什么?

更多相关阅读请进入《asp.net》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...