越來越多的項目需要用到實時消息的推送與接收,怎樣用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.