亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

搜索
博主信息
博文 263
粉絲 3
評論 2
訪問量 133790
最新下載
更多>
網(wǎng)站特效
網(wǎng)站源碼
網(wǎng)站素材
前端模板
使用GoEasy實現(xiàn)web實時消息推送
福哥的博客
原創(chuàng)
3567人瀏覽過

越來越多的項目需要用到實時消息的推送與接收,怎樣用PHP實現(xiàn)最方便呢?我這里推薦大家使用GoEasy, 它是一款第三方推送服務(wù)平臺,使用它的API可以輕松搞定實時推送!

瀏覽器兼容性:GoEasy推送 支持websocket 和polling兩種連接方式,從而可以支持IE6及其以上的所有版本,同時還支持其它瀏覽器諸如Firefox, Chrome, Safari 等等。

支持不同的開發(fā)語言:    GoEasy推送 提供了Restful API接口,無論你的后臺程序用的是哪種語言都可以通過RestfulAPI來實現(xiàn)后臺實時推送。如:Java, PHP, C#, Ruby, Python, C, C++, ASP.NET, Node.js...

支持后臺及前臺推送: 后臺用Restful API, 前臺用goeasy.js;運用十分簡單!


 PHP Web實時消息后臺服務(wù)器推送技術(shù)

 

下面我介紹一下使用GoEasy的步驟:

1. 你需要到goeasy官網(wǎng)上注冊一個賬號,并創(chuàng)建一個應(yīng)用,應(yīng)用創(chuàng)建好后系統(tǒng)會默認(rèn)為它生成兩個key: publish key 和subscribe key

2. 前臺實時訂閱及接收

    只需要引入goeasy.js(不能將goeasy.js下載到本地,因為goeasy會根據(jù)不同瀏覽器來提供不同的js
),然后調(diào)用goeasy的subscribe方法訂閱一個channel即可(我們也可以根據(jù)channel來控制哪些客戶端可以接收),訂閱時無論是用publish key還是subscribe key都可以。通過subscribe的參數(shù) onMessage的回調(diào)函數(shù)可以實時接收到消息。

3. 前臺實時推送

    還是需要引入goeasy.js(如果該頁面已經(jīng)引入了可不在引入),然后調(diào)用goeasy的publish方法向已訂閱的channel上推送消息即可,推送時只能用publish key。

4. 后臺實時推送

     調(diào)用GoEasyRestful API, 用post方式訪問http://goeasy.io/goeasy/publish,同時還需要帶上三個必要參數(shù):

    appkey: publish key

    channel: 你訂閱了的channel

   content: 推送內(nèi)容

就是這么簡單。

<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>

就是這么簡單就輕松實現(xiàn)了我的第一個web推送,連我自己都驚訝了。從官網(wǎng)的getting started頁面可以獲知,它還可以從后臺推送消息,有Java SDK (直接配maven庫),還支持Restful API這樣就可以支持多語言了,無論你是c#,還是PHP,還是python 還是其他,都可以用它來推送。

順便說一下,在docs下面是可以下載中文幫助文檔的哦!官網(wǎng)是:https://goeasy.io

同時也希望能給其他朋友帶來幫助。

****************************************************************************************************************

下面提供一個完整的例子,

php

  /**
     * 訂單提醒     */
    public function sendOrderNotice(){        //請求地址
        $uri = "http://goeasy.io/goeasy/publish";        // 參數(shù)數(shù)組
        $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 );//返回結(jié)果轉(zhuǎn)成字符串
        curl_setopt ( $ch, CURLOPT_POSTFIELDS, $data );//post傳輸?shù)臄?shù)據(jù)。
        $return = curl_exec ( $ch );
        curl_close ( $ch );        print_r($return);
    }

PHP發(fā)送消息提醒

成功則返回:

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一種新的協(xié)議。它實現(xiàn)了瀏覽器與服務(wù)器全雙工通信(full-duplex)。一開始的握手需要借助HTTP請求完成,當(dāng)瀏覽器和服務(wù)器握手成功后,瀏覽器和服務(wù)器之間就形成了一條快速通道。兩者之間就直接可以數(shù)據(jù)互相傳送。有了websocket, 大家就可以摒棄以往用輪詢來實現(xiàn)實時通訊的方式了。
有了websocket后,應(yīng)運而生的相關(guān)產(chǎn)品也不在少數(shù),選擇也成了最大的問題,在這里你可能會說“干嘛用別人的,我可以自己用原始的開發(fā)一個啊” 對此我只想說你真NB,我也很想知道你是如何解決以下問題的:
1. 你是打算花1個月,2個月還是1年還實現(xiàn)一個websocket通信的?如果你說你打算花一個月,那說明兩點,你的技術(shù)要上天了(這么刁的東西你可以那么快弄出來還不存在性能問題,除了我現(xiàn)有的膝蓋,請把我下輩子的膝蓋也拿走),貴公司土豪(貴公司對技術(shù)的炙熱追求已經(jīng)達到了行業(yè)的巔峰了,看來你們的項目不是很緊嘛,預(yù)算挺多嘛,告訴我貴公司的名字我也來鉆研技術(shù),哈哈哈)
2. Websocket只支持ie10+, chrome, firefox, safari, opera. 不說多了,當(dāng)前IE9及低版本的用戶群體還有很多,你是怎么覺得這些低版本瀏覽器的實時通訊的?
上面兩個問題無非就是涉及到兩方面問題:開發(fā)成本和瀏覽器兼容性問題。站在管理者角度來看,都希望盡可能多的壓縮開發(fā)成本,所有選擇第三方推送服務(wù)是眾多企業(yè)的一個理性選擇。
選擇產(chǎn)品時需要注意以下幾點:
1. 代碼結(jié)構(gòu)是否清晰易懂
2. 消息到達率怎么樣,數(shù)據(jù)到達情況是否可視
3. 瀏覽器兼容性如何
4. 產(chǎn)品的穩(wěn)定性和安全性
好,重點來了,我不去評判其他產(chǎn)品的優(yōu)缺點,只給出我對我最終選擇的產(chǎn)品-GoEasy推送作一個單方面的評價。GoEasy推送滿足我上面列的所有指標(biāo)。
1. 代碼結(jié)構(gòu)是否清晰易懂
GoEasy的代碼分為訂閱和推送兩部分:
訂閱時,只需要三句代碼:
a. 引入goeasy.js (文件非常?。?/p>

Javascript代碼  

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


b. 創(chuàng)建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來實現(xiàn),api只需要三個參數(shù)即可:
URL: http://goeasy.io/goeasy/publish
Method: Post
Parameters: appkey, channel, content
2. 消息到達率怎么樣,數(shù)據(jù)到達情況是否可視
我們項目的用戶并發(fā)量目前最高在300人的樣子,每天會推送30條消息的樣子,每條消息的到達情況都可以在goeasy后臺頁面進行查看。至于到達率,我們項目的對到達率的要求是98%, 就目前來看GoEasy應(yīng)該是100%的到達率。
3. 瀏覽器兼容性如何
除了常用的瀏覽器chrome, firefox, safari, opera外還支持IE 6到IE11的版本,低版本IE瀏覽器GoEasy采用的是polling的方式。GoEasy在兼容性這方面做的很不錯。
4. 產(chǎn)品的穩(wěn)定性和安全性
穩(wěn)定性的判定:項目已經(jīng)持續(xù)運行了4個月了,沒有出現(xiàn)過消息推不出或接收不到的情況。
安全性的判定:GoEasy在安全控制方面主要是通過appkey來控制,創(chuàng)建好app后系統(tǒng)會生成兩個key,一個既可以用來接收又可以用來推送,另一個只可以用來接收。所以用戶可以選擇性的暴露你的key.
這樣輕松用PHP實現(xiàn)客戶端與服務(wù)器端的實時通信了

本博文版權(quán)歸博主所有,轉(zhuǎn)載請注明地址!如有侵權(quán)、違法,請聯(lián)系admin@php.cn舉報處理!
全部評論 文明上網(wǎng)理性發(fā)言,請遵守新聞評論服務(wù)協(xié)議
0條評論
作者最新博文
關(guān)于我們 免責(zé)申明 意見反饋 講師合作 廣告合作 最新更新
php中文網(wǎng):公益在線php培訓(xùn),幫助PHP學(xué)習(xí)者快速成長!
關(guān)注服務(wù)號 技術(shù)交流群
PHP中文網(wǎng)訂閱號
每天精選資源文章推送
PHP中文網(wǎng)APP
隨時隨地碎片化學(xué)習(xí)
PHP中文網(wǎng)抖音號
發(fā)現(xiàn)有趣的

Copyright 2014-2025 http://ipnx.cn/ All Rights Reserved | php.cn | 湘ICP備2023035733號

  • 登錄PHP中文網(wǎng),和優(yōu)秀的人一起學(xué)習(xí)!
    全站2000+教程免費學(xué)