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

    xiaoxiao2022-06-22  24

    以前都是使用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 代码

    GoEasy goEasy = new GoEasy("03**********************51"); goEasy.publish("系统通知", "系统将于今天中午十二点进行维护,届时系统不可用。", new PublishListener() { @Override public void onFailed(GoEasyError error) { System.out.println("推送失败了,Error code:" + error.getCode() + "; error content:" + error.getContent()); } @Override public void onSuccess() { System.out.println("推送成功"); } });   初始化GoEasy对象时,需要一个appkey.这个appkey需要大家自己去goeasy官网注册并创建一个app (大家可以先创建一个免费的app来测试) 到这里为止后台代码就已经完毕了。  

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

    <script type="text/javascript" src="http://cdn.goeasy.io/goeasy.js"></script> 2.2. 订阅

    <script type="text/javascript"> var goEasy = new GoEasy({appkey: '03**********************51'}); goEasy.subscribe({ channel: '系统通知', onMessage: function(message){ alert('收到:'+message.content); } }); </script>

    3. 最后一步确保在推送前订阅了的web页面已经打开(先订阅后推送),推送后你的消息会在订阅的web页面弹出来 除了Java后台推送之外,goeasy同时也提供了Restful API 供其开发语言的用户轻松实现实时web推送,如C#服务器实时推送,asp.net服务器实时推送, python服务器实时推送, PHP服务器实时推送, Ruby服务器实时推送.

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

    goEasy.publish({ channel: '系统推送l', message: '来自web的推送消息:接收到了您的推送消息' });

    转载请注明原文地址: https://ju.6miu.com/read-1122793.html

    最新回复(0)