学编程 ❀(๑╯◡╰๑)❀ 就上soxunxi.cn!这里有CMS,CSS,NET,PHP,Linux,HTML,JAVA,MySQL,Python等教程.
当前位置: NET > ASP.NET完成音讯推送的示例代码【C#.Net教程】,ASP.NET实现消息推送,Signair推送即时消息,Signalr实现消息推送

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

 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内里追加以下代码

public void Configuration(IAppBuilder app)
    {
      app.MapSignalR<MyConnection1>("/myconnection");
    }

诠释:接见myconnection的时刻,触发MyConnection1

5.增添客户端【h5】

@{
  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

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

9.新建js推送demo

  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.组合二者

  //及时推送
  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.完成服务器的主动推送.现只引见播送。单推道理一致。

分为播送及单推两种形式。

播送:

 var context = GlobalHost.ConnectionManager.GetConnectionContext<MyConnection1>();//猎取你当前的Connection衔接
  context.Connection.Broadcast("我是一条新的推送音讯!");//播送推送

单推:

 var context = GlobalHost.ConnectionManager.GetConnectionContext<MyConnection1>();//猎取你当前的Connection衔接
 context.Connection.Send(connectionId, "Welcome!");//单推事列

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

13.结果以下:

如许当我们服务端处置惩罚某个使命时就能够挪用播送来完成主动推送到客户端,举行数据的立即更新及音讯的推送。

【相干引荐】

1. 迥殊引荐:“php程序员东西箱”V0.1版本下载

2. ASP免费视频教程

3. ASP参考手册

以上就是ASP.NET完成音讯推送的示例代码的细致内容,更多请关注ki4网别的相干文章!

「梦想一旦被付诸行动,就会变得神圣,如果觉得我的文章对您有用,请帮助本站成长」

分享到:
赞(0) 打赏

支付宝扫一扫打赏

微信扫一扫打赏

上一篇:

下一篇:

相关推荐

0 条评论关于"ASP.NET完成音讯推送的示例代码【C#.Net教程】,ASP.NET实现消息推送,Signair推送即时消息,Signalr实现消息推送"

最新评论

    暂无留言哦~~

博客简介

看古风美女插画Cos小姐姐,素材合集图集打包下载:炫龙网,好看二次元插画应有尽有,唯美小姐姐等你来。

友情链接

他们同样是一群网虫,却不是每天泡在网上游走在淘宝和网游之间、刷着本来就快要透支的信用卡。他们或许没有踏出国门一步,但同学却不局限在一国一校,而是遍及全球!申请交换友链

服务热线:
 

 QQ在线交流

 旺旺在线