越来越多的项目需要用到实时消息的推送与接收,我这里推荐大家使用GoEasy, 它是一款第三方推送服务平台,使用它的API可以轻松搞定实时推送!

浏览器兼容性:GoEasy推送 支持websocket 和polling两种连接方式,从而可以支持IE6及其以上的所有版本,同时还支持其它浏览器诸如Firefox, Chrome, Safari等等。

支持不同的开发语言:GoEasy推送 提供了Restful API接口,无论你的后台程序用的是哪种语言都可以通过Restful API来实现后台实时推送。如:Java,PHP, C#, Ruby, Python, C, C++, ASP.NET,Node.js...

支持后台及前台推送: 后台用Restful API, 前台用goeasy.js; 运用十分简单!

下面我介绍一下使用GoEasy的步骤:

1. 你需要到goeasy官网上注册一个账号,并创建一个应用,应用创建好后系统会默认为它生成两个key: publish key和subscribe key

2. 前台实时订阅及接收

只需要引入goeasy.js,然后调用goeasy的subscribe方法订阅一个channel即可,订阅时无论是用publish key还是subscribe key都可以。通过subscribe的参数 onMessage的回调函数可以实时接收到消息。

3. 前台实时推送

还是需要引入goeasy.js(如果该页面已经引入了可不在引入),然后调用goeasy的publish方法向已订阅的channel上推送消息即可,推送时只能用publish key。

4. 后台实时推送

调用GoEasy Restful API, 用post方式访问http://goeasy.io/goeasy/publish, 同时还需要带上三个必要参数:

appkey: publish key

channel: 你订阅了的channel

content: 推送内容

就是这么简单。

推送的原理:GoEasy的实现原理很简单,就是推送消息的一端只负责推送,而需要接收的页面需要预先订阅。订阅什么呢?订阅channel。往 某个channel上推送消息,客户端就订阅相同的channel,这样就可以确保准确接收。通过channel我们可以自己指定哪些页面或哪些用户可以 接收到从这个channel上推送出来的消息。

下面我将之前写的一个小实例贴出来,里面用了Javascript 在web页面进行订阅,推送,接收,以及取消订阅的例子,里面的appkey用的是goeasy官方的demo 的appkey.

GoEasy Test

if(typeof GoEasy !== 'undefined'){

var goEasy = new GoEasy({

appkey: 'ba821151-e043-4dfb-a954-c73744c8d323',

userId:"222",

username:"22",

onConnected:function(){

console.log("Connect to GoEasy success.");

} ,

onDisconnected:function(){

console.log("Disconnect to GoEasy server.");

} ,

onConnectFailed:function(error){

console.log("Connect to GoEasy failed, error code: "+ error.code+" Error message: "+ error.content);

}

});

}

subscribe();

function subscribe(){

goEasy.subscribe({

channel: 'notification',

onMessage: function(message){

console.log('Meessage received:'+message.content);

},

onSuccess:function(){

console.log("Subscribe the Channel successfully.");

},

onFailed: function(error){

console.log("Subscribe the Channel failed, error code: "+ error.code + " error message: "+ error.content);

}

});

}

function publishMessage(){

goEasy.publish({

channel: 'notification',

message: 'You received a new notification',

onSuccess:function(){

console.log("Publish message success.");

},

onFailed: function(error){

console.log("Publish message failed, error code: "+ error.code +" Error message: "+ error.content);

}

});

}

function unsubscribe(){

goEasy.unsubscribe({

channel:"notification",

onSuccess: function(){

console.log("Cancel Subscription successfully.");

},

onFailed: function(error){

console.log("Cancel the subscrition failed, error code: "+ error.code + "error message: "+ error.content);

}

});

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

java实时推送goeasy_JAVA Web实时消息后台服务器推送技术---GoEasy相关推荐

  1. Python Web实时消息后台服务器推送技术---GoEasy

    越来越多的项目需要用到实时消息的推送与接收,怎样实现最方便呢?我这里推荐大家使用GoEasy,它是一款第三方推送服务平台,使用它的API可以轻松搞定实时推送! 浏览器兼容性:GoEasy推送 支持we ...

  2. C# Web实时消息后台服务器推送技术---GoEasy

    越来越多的项目需要用到实时消息的推送与接收,怎样实现最方便呢?我这里推荐大家使用GoEasy, 它是一款第三方推送服务平台,使用它的API可以轻松搞定实时推送! 浏览器兼容性:GoEasy推送 支持w ...

  3. ASP.NET Web实时消息后台服务器推送技术---GoEasy

    越来越多的项目需要用到实时消息的推送与接收,怎样用ASP.NET实现最方便呢?我这里推荐大家使用GoEasy, 它是一款第三方推送服务平台,使用它的API可以轻松搞定实时推送! 浏览器兼容性:GoEa ...

  4. C# Web实时消息后台服务器推送技术-GoEasy

    越来越多的项目需要用到实时消息的推送与接收,怎样用C#实现最方便呢?我这里推荐大家使用GoEasy, 它是一款第三方推送服务平台,使用它的API可以轻松搞定实时推送! 浏览器兼容性:GoEasy推送 ...

  5. Ruby Web实时消息后台服务器推送技术---GoEasy

    越来越多的项目需要用到实时消息的推送与接收,怎样实现最方便呢?我这里推荐大家使用GoEasy,它是一款第三方推送服务平台,使用它的API可以轻松搞定实时推送! 浏览器兼容性:GoEasy推送 支持we ...

  6. .NET Web实时消息后台服务器推送技术-GoEasy

    越来越多的项目需要用到实时消息的推送与接收,怎样用.NET实现最方便呢?我这里推荐大家使用GoEasy, 它是一款第三方推送服务平台,使用它的API可以轻松搞定实时推送! 浏览器兼容性:GoEasy推 ...

  7. PHP Web实时消息后台服务器推送技术---GoEasy

    越来越多的项目需要用到实时消息的推送与接收,怎样用PHP实现最方便呢?我这里推荐大家使用GoEasy, 它是一款第三方推送服务平台,使用它的API可以轻松搞定实时推送! 浏览器兼容性:GoEasy推送 ...

  8. Web实时消息后台服务器推送技术GoEasy(支持多语言)---附GoEasy web 推送实例

    越来越多的项目需要用到实时消息的推送与接收,怎样实现最方便呢?我这里推荐大家使用 GoEasy, 它是一款第三方推送服务平台,使用它的 API可以轻松搞定实时推送! 浏览器兼容性:GoEasy推送 支 ...

  9. dwr 后台服务器推送技术

    刚才写了一篇<dwr传对象到前台>,现在继续下一个总结点,dwr又一个令人兴奋的技术后台服务器推送技术,需要的包我就不写了 web.xml配置 <servlet>   < ...

  10. 基于极光推送的web,app消息系统

    设计要点 1.web,app注册系统同时注册极光IM 2.WEB集成IM sdk,用户WEB登录与极光IM建立长连接 3.后端调用极光IM API给WEB用户推送消息,并将信息存入持久化到DB 4.用 ...

最新文章

  1. python简单还是c简单_Python与C的简单比较(Python3.0)
  2. 《游戏脚本的设计与开发》-第一部分总结 文字脚本的功能扩展和一个游戏测试...
  3. c# 过滤HTML代码 源代码,案例 下载
  4. windows 10开机后弹出的certificate选择弹出窗
  5. window server 安装与卸载
  6. python函数参数那些事,关键字参数与位置参数
  7. Kali学习笔记5:被动信息收集工具集
  8. 开发接口文档_产品经理必懂的接口文档撰写方式
  9. 【渝粤教育】电大中专跨境电子商务理论与实务 (3)作业 题库
  10. OpenCV运动目标检测背景差法和帧差法的理解
  11. 软件项目管理1:开发计划和版本计划举例
  12. 几款项目管理工具对比
  13. 学习PLC不可错过的15个基础!
  14. 深圳中院判决:利用网络爬虫技术抓取他人数据构成不正当竞争
  15. 计算机硬盘坏道有什么特点,硬盘坏道对电脑会造成什么影响
  16. 8.19! 今天我有18生日,点击阅读或顶部 尾随幸运的一天!生日知识!↓——【Badboy】...
  17. Windows远程桌面服务漏洞(CVE-2019-0708)复现测试
  18. 佛山c语言培训学校,佛山C语言培训:如何轻松学习C语言?
  19. [linux] 命令对应英文全称
  20. DCN神州数码交换机端口安全配置命令(纯命令)

热门文章

  1. 手把手教你如何进行内网渗透
  2. 利用EnableQ服务政府民意调查
  3. 教你如何在Protel中显示标题栏内容
  4. 网络编程在线英英词典之注册模块实现(三)
  5. Filezilla Server使用教程
  6. 在windows 2003系统上安装诺基亚pc套件以及笔记本通过PC套件上网
  7. arduino学习笔记-库函数解析_LiquidCrystal_i2c使用说明以及lcd1602的驱动
  8. html超链接图标图片,HTML-标签:图片 超链接
  9. 良心安利三大游戏音效素材网站
  10. java从JDK里提取全球数据,包含国家(名称、二字代码、三字代码)、币种(名称和代码)、和语言种类的数据