JAVA Web实时消息后台服务器推送技术---GoEasy
越来越多的项目需要用到实时消息的推送与接收,我这里推荐大家使用GoEasy,它是一款第三方推送服务平台,使用它的API可以轻松搞定实时推送!
浏览器兼容性:GoEasy推送支持websocket和polling两种连接方式,从而可以支持IE6及其以上的所有版本,同时还支持其它浏览器诸如Firefox,Chrome,Safari等等。
支持不同的开发语言:GoEasy推送提供了RestfulAPI接口,无论你的后台程序用的是哪种语言都可以通过RestfulAPI来实现后台实时推送。如:Java,PHP,C#,Ruby,Python,C,C++,ASP.NET,Node.js...
支持后台及前台推送:后台用RestfulAPI,前台用goeasy.js;运用十分简单!
下面我介绍一下使用GoEasy的步骤:
1.你需要到goeasy官网上注册一个账号,并创建一个应用,应用创建好后系统会默认为它生成两个key:publishkey和subscribekey
2.前台实时订阅及接收
只需要引入goeasy.js,然后调用goeasy的subscribe方法订阅一个channel即可,订阅时无论是用publishkey还是subscribekey都可以。通过subscribe的参数onMessage的回调函数可以实时接收到消息。
3.前台实时推送
还是需要引入goeasy.js(如果该页面已经引入了可不在引入),然后调用goeasy的publish方法向已订阅的channel上推送消息即可,推送时只能用publishkey。
4.后台实时推送
调用GoEasyRestfulAPI,用post方式访问http://goeasy.io/goeasy/publish,同时还需要带上三个必要参数:
- appkey:publishkey
- channel:你订阅了的channel
- content:推送内容
就是这么简单。
推送的原理:GoEasy的实现原理很简单,就是推送消息的一端只负责推送,而需要接收的页面需要预先订阅。订阅什么呢?订阅channel。往某个channel上推送消息,客户端就订阅相同的channel,这样就可以确保准确接收。通过channel我们可以自己指定哪些页面或哪些用户可以接收到从这个channel上推送出来的消息。
下面我将之前写的一个小实例贴出来,里面用了Javascript在web页面进行订阅,推送,接收,以及取消订阅的例子,里面的appkey用的是goeasy官方的demo的appkey.
<html> <head> <title>GoEasyTest</title> <scripttype="text/javascript"src="https://cdn.goeasy.io/goeasy.js"></script> <scripttype="text/javascript"> if(typeofGoEasy!=='undefined'){ vargoEasy=newGoEasy({ appkey:'ba821151-e043-4dfb-a954-c73744c8d323', userId:"222", username:"22", onConnected:function(){ console.log("ConnecttoGoEasysuccess."); }, onDisconnected:function(){ console.log("DisconnecttoGoEasyserver."); }, onConnectFailed:function(error){ console.log("ConnecttoGoEasyfailed,errorcode:"+error.code+"Errormessage:"+error.content); } }); } subscribe(); functionsubscribe(){ goEasy.subscribe({ channel:'notification', onMessage:function(message){ console.log('Meessagereceived:'+message.content); }, onSuccess:function(){ console.log("SubscribetheChannelsuccessfully."); }, onFailed:function(error){ console.log("SubscribetheChannelfailed,errorcode:"+error.code+"errormessage:"+error.content); } }); } functionpublishMessage(){ goEasy.publish({ channel:'notification', message:'Youreceivedanewnotification', onSuccess:function(){ console.log("Publishmessagesuccess."); }, onFailed:function(error){ console.log("Publishmessagefailed,errorcode:"+error.code+"Errormessage:"+error.content); } }); } functionunsubscribe(){ goEasy.unsubscribe({ channel:"notification", onSuccess:function(){ console.log("CancelSubscriptionsuccessfully."); }, onFailed:function(error){ console.log("Cancelthesubscritionfailed,errorcode:"+error.code+"errormessage:"+error.content); } }); } </script> </head> <body> <inputtype="button"value="publish"onclick="publishMessage()"/> <inputtype="button"value="unsubscribe"onclick="unsubscribe()"/> <inputtype="button"value="subscribe"onclick="subscribe()"/> </body> </html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。