基于GoEasy实现Java web实时数据推送

 以前都是使用ajax定时发送请求到后台,这种方式非常消耗系统资源。在大并发情况时如果不对线程进行控制的话,还会重复取数据,造成数据错误。
   鉴于这种情况,使用websocket通信就是一个非常好的选择。websocket能避免浪费系统资源,但是它有一个缺点就是不兼容低版本的IE浏览器(貌似是只支持IE10及以上的IE版本)。为了解决这个问题,我在网上逛了一圈,最终找到了GoEasy推送,网上说它是基于websocket和polling两种通信方式而开发的实时推送服务平台。通过测试得出,低版本的IE浏览器都是通过polling方式连接的,而其它浏览器都是websocket。GoEasy官网:http://goeasy.io
下面介绍如何使用GoEasy从java后台推送实时消息。
1. 从Java后台推送消息

1.1. 引入goeasy的Java SDK; 大家也可以通过maven将goeasy加入到项目中。SDK的下载和maven配置请大家从goeasy官网上获取: http://goeasy.io/www/started

快照

1.2. Java 代码

  1. GoEasy goEasy = new GoEasy("03**********************51");    
  2. goEasy.publish("系统通知""系统将于今天中午十二点进行维护,届时系统不可用。"new PublishListener() {    
  3.     @Override    
  4.     public void onFailed(GoEasyError error) {    
  5.         System.out.println("推送失败了,Error code:" + error.getCode() + "; error content:" + error.getContent());    
  6.     }    
  7.     @Override    
  8.     public void onSuccess() {    
  9.         System.out.println("推送成功");    
  10.     }    
  11. });    

 
初始化GoEasy对象时,需要一个appkey.这个appkey需要大家自己去goeasy官网注册并创建一个app (大家可以先创建一个免费的app来测试)
到这里为止后台代码就已经完毕了。  

2. Web页面接收
2.1. 引入goeasy.js

[javascript] view plain copy
  1. <script type="text/javascript" src="http://cdn.goeasy.io/goeasy.js"></script>    

2.2. 订阅
[javascript] view plain copy
  1. <script type="text/javascript">    
  2.   var goEasy = new GoEasy({appkey: '03**********************51'});    
  3.   goEasy.subscribe({    
  4.     channel: '系统通知',    
  5.     onMessage: function(message){    
  6.       alert('收到:'+message.content);    
  7.     }    
  8.     });    
  9. </script>   

3. 最后一步确保在推送前订阅了的web页面已经打开(先订阅后推送),推送后你的消息会在订阅的web页面弹出来


除了Java后台推送之外,goeasy同时也提供了Restful API 供其开发语言的用户轻松实现实时web推送,如C#服务器实时推送,asp.net服务器实时推送, python服务器实时推送, PHP服务器实时推送, Ruby服务器实时推送.

当然,goeasy也提供从web页面直接推送消息的功能:

[javascript] view plain copy
  1. goEasy.publish({    
  2.      channel: '系统推送l',    
  3.      message: '来自web的推送消息:接收到了您的推送消息'    
  4. });   
阅读更多 登录后自动展开
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页