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


Posted in Javascript onNovember 04, 2016

越来越多的项目需要用到实时消息的推送与接收,我这里推荐大家使用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.

<html>
<head>
<title>GoEasy Test</title>

<script type="text/javascript" src="https://cdn.goeasy.io/goeasy.js"></script>
<script type="text/javascript">
  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);
          }

        });
      }
    
 </script>
</head>
<body>
 <input type="button" value="publish" onclick="publishMessage()"/>
 <input type="button" value="unsubscribe" onclick="unsubscribe()"/>
 <input type="button" value="subscribe" onclick="subscribe()"/>
</body>
</html>

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

Javascript 相关文章推荐
jQuery+ajax实现顶一下,踩一下效果
Jul 17 Javascript
通过百度地图获取公交线路的站点坐标的js代码
May 11 Javascript
javascript加号&quot;+&quot;的二义性说明
Mar 04 Javascript
javascript列表框操作函数集合汇总
Nov 28 Javascript
javascript使用window.open提示“已经计划系统关机”的原因
Aug 15 Javascript
基于js里调用函数时,函数名带括号和不带括号的区别
Jul 28 Javascript
js+div+css下拉导航菜单完整代码分享
Dec 28 Javascript
javascript中的深复制详解及实例分析
Dec 29 Javascript
基于Vue实例对象的数据选项
Aug 09 Javascript
jQuery绑定事件方法及区别(bind,click,on,live,one)
Aug 14 jQuery
细说webpack源码之compile流程-rules参数处理技巧(1)
Dec 26 Javascript
Vue+Element UI 树形控件整合下拉功能菜单(tree + dropdown +input)
Aug 28 Javascript
详解js运算符单竖杠“|”与“||”的用法和作用介绍
Nov 04 #Javascript
使用Ajax与服务器(JSON)通信实例
Nov 04 #Javascript
AngularJS过滤器filter用法实例分析
Nov 04 #Javascript
URL的参数中有加号传值变为空格的问题(URL特殊字符)
Nov 04 #Javascript
Angular页面间切换及传值的4种方法
Nov 04 #Javascript
AngularJS实现根据变量改变动态加载模板的方法
Nov 04 #Javascript
RGB和YUV 多媒体编程基础详细介绍
Nov 04 #Javascript
You might like
第九节--绑定
2006/11/16 PHP
UCenter 批量添加用户的php代码
2012/07/17 PHP
PHP中使用匿名函数操作数据库的例子
2014/11/17 PHP
浅谈php和js中json的编码和解码
2016/10/24 PHP
PHP PDO数据库操作预处理与注意事项
2019/03/16 PHP
非常不错的功能强大代码简单的管理菜单美化版
2008/07/09 Javascript
js中字符替换函数String.replace()使用技巧
2011/08/14 Javascript
JQuery AJAX 中文乱码问题解决
2013/06/05 Javascript
详解JavaScript中的客户端消息框架设计原理
2015/06/24 Javascript
理解JavaScript表单的基础知识
2016/01/25 Javascript
手机端js和html5刮刮卡效果
2020/09/29 Javascript
js实现图片加载淡入淡出效果
2017/04/07 Javascript
Vue开发中整合axios的文件整理
2017/04/29 Javascript
用js实现每隔一秒刷新时间的实例(含年月日时分秒)
2017/10/25 Javascript
JavaScript EventEmitter 背后的秘密 完整版
2018/03/29 Javascript
vue+eslint+vscode配置教程
2019/08/09 Javascript
js实现移动端tab切换时下划线滑动效果
2019/09/08 Javascript
谈谈IntersectionObserver懒加载的具体使用
2019/10/15 Javascript
javascript canvas检测小球碰撞
2020/04/17 Javascript
在antd Form表单中select设置初始值操作
2020/11/02 Javascript
ant-design-vue中tree增删改的操作方法
2020/11/03 Javascript
前端vue如何使用高德地图
2020/11/05 Javascript
微信小程序 接入腾讯地图的两种写法
2021/01/12 Javascript
[01:11:21]DOTA2-DPC中国联赛 正赛 VG vs Elephant BO3 第一场 3月6日
2021/03/11 DOTA
Python配置文件解析模块ConfigParser使用实例
2015/04/13 Python
Python易忽视知识点小结
2015/05/25 Python
在Python的Django框架中编写错误提示页面
2015/07/22 Python
Python线性方程组求解运算示例
2018/01/17 Python
python re模块findall()函数实例解析
2018/01/19 Python
python爬虫爬取网页表格数据
2018/03/07 Python
Python中字符串String的基本内置函数与过滤字符模块函数的基本用法
2019/05/27 Python
python实现WebSocket服务端过程解析
2019/10/18 Python
Python插入Elasticsearch操作方法解析
2020/01/19 Python
Kiehl’s科颜氏西班牙官方网站:源自美国的植物护肤品牌
2020/02/22 全球购物
创先争优演讲稿
2014/09/15 职场文书
升学宴家长答谢词
2015/09/29 职场文书