使用GoEasy實現web實時消息推送


  越來越多的項目需要用到實時消息的推送與接收,怎樣用PHP實現最方便呢?我這里推薦大家使用GoEasy, 它是一款第三方推送服務平台,使用它的API可以輕松搞定實時推送!
  瀏覽器兼容性:GoEasy推送 支持websocket 和polling兩種連接方式,從而可以支持IE6及其以上的所有版本,同時還支持其它瀏覽器諸如Firefox, Chrome, Safari 等等。
  支持不同的開發語言: GoEasy推送 提供了Restful API接口,無論你的后台程序用的是哪種語言都可以通過RestfulAPI來實現后台實時推送。如:Java, PHP, C#, Ruby, Python, C, C++, ASP.NET, Node.js……
  支持后台及前台推送: 后台用Restful API, 前台用goeasy.js;運用十分簡單!https://www.weixiu3721.com
  PHP Web實時消息后台服務器推送技術
  下面我介紹一下使用GoEasy的步驟:
  1. 你需要到goeasy官網上注冊一個賬號,並創建一個應用,應用創建好后系統會默認為它生成兩個key: publish key 和subscribe key
  2. 前台實時訂閱及接收
  只需要引入goeasy.js(不能將goeasy.js下載到本地,因為goeasy會根據不同瀏覽器來提供不同的js
  ),然后調用goeasy的subscribe方法訂閱一個channel即可(我們也可以根據channel來控制哪些客戶端可以接收),訂閱時無論是用publish key還是subscribe key都可以。通過subscribe的參數 onMessage的回調函數可以實時接收到消息。
  3. 前台實時推送
  還是需要引入goeasy.js(如果該頁面已經引入了可不在引入),然后調用goeasy的publish方法向已訂閱的channel上推送消息即可,推送時只能用publish key。
  4. 后台實時推送
  調用GoEasyRestful API, 用post方式訪問http://goeasy.io/goeasy/publish,同時還需要帶上三個必要參數:
  appkey: publish key
  channel: 你訂閱了的channel
  content: 推送內容
  就是這么簡單。
  <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: '{your appkey}'
  });
  }
  //頁面一加載就訂閱
  goEasy.subscribe({
  channel: 'demo_channel',
  onMessage: function(message){ console.log('Meessage received:'+message.content);
  }
  }); //推送消息
  function publishMessage(){
  goEasy.publish({
  channel: 'demo_channel',
  message: '第一條信息'
  });
  }
  //取消訂閱的頁面不會再收到信息
  function unsubscribe(){
  goEasy.unsubscribe({
  channel:"demo_channel"
  });
  }
  </script></head><body>
  <input type="button" value=“推送消息” onclick="publishMessage()"/>
  <input type="button" value=“取消訂閱” onclick="unsubscribe()"/></body></html>
  就是這么簡單就輕松實現了我的第一個web推送,連我自己都驚訝了。從官網的getting started頁面可以獲知,它還可以從后台推送消息,有Java SDK (直接配maven庫),還支持Restful API這樣就可以支持多語言了,無論你是c#,還是PHP,還是python 還是其他,都可以用它來推送。
  順便說一下,在docs下面是可以下載中文幫助文檔的哦!官網是:https://goeasy.io
  同時也希望能給其他朋友帶來幫助。
  ****************************************************************************************************************
  下面提供一個完整的例子,
  php
  /**
  * 訂單提醒 */
  public function sendOrderNotice(){ //請求地址
  $uri = "http://goeasy.io/goeasy/publish"; // 參數數組
  $data = [ 'appkey' => "你的APPkey",
  'channel' => "demo",
  'content' =>“您有新的訂單”
  ]; $ch = curl_init ();
  curl_setopt ( $ch, CURLOPT_URL, $uri );//地址
  curl_setopt ( $ch, CURLOPT_POST, 1 );//請求方式為post
  curl_setopt ( $ch, CURLOPT_HEADER, 0 );//不打印header信息
  curl_setopt ( $ch, CURLOPT_RETURNTRANSFER, 1 );//返回結果轉成字符串
  curl_setopt ( $ch, CURLOPT_POSTFIELDS, $data );//post傳輸的數據。
  $return = curl_exec ( $ch );
  curl_close ( $ch ); print_r($return);
  }
  PHP發送消息提醒
  成功則返回:
  1128628-20170616172725696-12817296.png
  JS
  <script type="text/javascript" src="http://cdn.goeasy.io/goeasy.js"></script>
  <script type="text/javascript"> var goeasy = new GoEasy({
  appkey: '你的appkey'
  });
  goeasy.subscribe({
  channel: 'demo',
  onMessage: function(message){
  alert('Receive:'+message.content);
  }
  }); </script>
  JS接受消息
  22222.png
  ************************************************************************************************************************
  說到websocket大家一定不會陌生,WebSocket是HTML5一種新的協議。它實現了瀏覽器與服務器全雙工通信(full-duplex)。一開始的握手需要借助HTTP請求完成,當瀏覽器和服務器握手成功后,瀏覽器和服務器之間就形成了一條快速通道。兩者之間就直接可以數據互相傳送。有了websocket, 大家就可以摒棄以往用輪詢來實現實時通訊的方式了。
  有了websocket后,應運而生的相關產品也不在少數,選擇也成了最大的問題,在這里你可能會說“干嘛用別人的,我可以自己用原始的開發一個啊” 對此我只想說你真NB,我也很想知道你是如何解決以下問題的:
  1. 你是打算花1個月,2個月還是1年還實現一個websocket通信的?如果你說你打算花一個月,那說明兩點,你的技術要上天了(這么刁的東西你可以那么快弄出來還不存在性能問題,除了我現有的膝蓋,請把我下輩子的膝蓋也拿走),貴公司土豪(貴公司對技術的炙熱追求已經達到了行業的巔峰了,看來你們的項目不是很緊嘛,預算挺多嘛,告訴我貴公司的名字我也來鑽研技術,哈哈哈)
  2. Websocket只支持ie10+, chrome, firefox, safari, opera. 不說多了,當前IE9及低版本的用戶群體還有很多,你是怎么覺得這些低版本瀏覽器的實時通訊的?
  上面兩個問題無非就是涉及到兩方面問題:開發成本和瀏覽器兼容性問題。站在管理者角度來看,都希望盡可能多的壓縮開發成本,所有選擇第三方推送服務是眾多企業的一個理性選擇。
  選擇產品時需要注意以下幾點:
  1. 代碼結構是否清晰易懂
  2. 消息到達率怎么樣,數據到達情況是否可視
  3. 瀏覽器兼容性如何
  4. 產品的穩定性和安全性
  好,重點來了,我不去評判其他產品的優缺點,只給出我對我最終選擇的產品-GoEasy推送作一個單方面的評價。GoEasy推送滿足我上面列的所有指標。
  1. 代碼結構是否清晰易懂
  GoEasy的代碼分為訂閱和推送兩部分:
  訂閱時,只需要三句代碼:
  a. 引入goeasy.js (文件非常小)
  Javascript代碼
  <script type="text/javascript" src="http://cdn.goeasy.io/goeasy.js"></script>
  b. 創建goeasy實例
  Javascript代碼
  var goEasy = new GoEasy({appkey: 'appkey'});
  c. 訂閱channel.
  Javascript代碼
  goEasy. subscribe({
  channel: 'channel1',
  onMessage: function(message){
  alert('Meessage received:'+message.content);//接收到推送的消息
  }
  });
  推送時,用goeasy提供的restful api來實現,api只需要三個參數即可:
  URL: http://goeasy.io/goeasy/publish
  Method: Post
  Parameters: appkey, channel, content
  2. 消息到達率怎么樣,數據到達情況是否可視
  我們項目的用戶並發量目前最高在300人的樣子,每天會推送30條消息的樣子,每條消息的到達情況都可以在goeasy后台頁面進行查看。至於到達率,我們項目的對到達率的要求是98%, 就目前來看GoEasy應該是100%的到達率。
  3. 瀏覽器兼容性如何https://www.weixiu3721.com
  除了常用的瀏覽器chrome, firefox, safari, opera外還支持IE 6到IE11的版本,低版本IE瀏覽器GoEasy采用的是polling的方式。GoEasy在兼容性這方面做的很不錯。
  4. 產品的穩定性和安全性
  穩定性的判定:項目已經持續運行了4個月了,沒有出現過消息推不出或接收不到的情況。
  安全性的判定:GoEasy在安全控制方面主要是通過appkey來控制,創建好app后系統會生成兩個key,一個既可以用來接收又可以用來推送,另一個只可以用來接收。所以用戶可以選擇性的暴露你的key.


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM