ASP.NET 基于 websocket 的前台及后台实时推送

2017-01-20 12:19:21 +08:00
 HongHuangZhiLi

实现步骤如下:

1.获取 GoEasy appkey.

在 goeasy 官网上注册一个账号,并新建一个 app. APP 创建好后系统会为该 app 自动生成两个 key, 一个既可以用来接收又可以用来推送 (supper key),另一个只可以用来接收(subscriber key).

2.客户端订阅一个 channel.

a. 在客户端引入 goeasy.js , js 地址: http://cdn.goeasy.io/goeasy.js

需要注意的是,不能将 goeasy.js 下载到本地,因为 goeasy 会根据不同浏览器来提供不同的 js. 官网上也有相应说明。

b. 订阅代码

var goEasy = new GoEasy({appkey: 'subscriber key'});//这里我用的是 subscriber key,因为在我的客户端我不需要推送任何消息,所以没有必要使用 supper key goEasy. subscribe({ channel: 'csdnNotification', onMessage: function(message){ alert('Meessage received:'+message.content);//接收到推送的消息 } });

3.前台推送及后台推送

3.1. 前台往相同 channel 上推送

在引入了 goeasy.js 的页面,直接调用 goEasy. publish('csdnNotification', '天天想你'); 用法与订阅类似。

3.2. 后台往相同 channel 上推送. 用 GoEasy 提供的 restful API 实现

API url: http://goeasy.io/goeasy/publish 方式: Post 参数列表: channel: 'csdnNotification' //与订阅的 channel 必须一致,否则客户端将收不到消息。因此我们也可以根据 channel 来控制哪些客户端可以接收。 appkey: 'supper key' //这里必须使用 supper key content: 'blabla …..' //要推送的内容

11030 次点击
所在节点    App.net
2 条回复
HongHuangZhiLi
2017-09-27 10:45:29 +08:00
GoEasy 实时 Web 推送,支持后台推送和前台推送两种:后台推送可以选择 Java SDK、Restful API 支持所有开发语言;前台推送:JS 推送。无论选择哪种方式推送代码都十分简单( 10 分钟可搞定)。由于它支持 websocket 和 polling 两种连接方式所以兼顾大多数主流浏览器,低版本的 IE 浏览器也是支持的。另外 GoEasy 针对前台推送采用 OTP (one-time-password)方式加密方式,能有效杜绝他人通过在页面上获取 appkey 的方式,进行非法操作,十分安全! GoEasy 多机房部署,支持全球推送。个人觉得十分值得推荐:goeasy.io
wysnylc
2017-11-10 09:54:47 +08:00
@HongHuangZhiLi 貌似只有这一家在做 web 推送

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/335812

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX