PHP Web實時消息後臺服務器推送技術---GoEasy

愈來愈多的項目須要用到實時消息的推送與接收,怎樣用php實現最方便呢?我這裏推薦你們使用GoEasy, 它是一款第三方推送服務平臺,使用它的API能夠輕鬆搞定實時推送!javascript

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

支持不一樣的開發語言:    GoEasy推送 提供了Restful API接口,不管你的後臺程序用的是哪一種語言均可以經過Restful API來實現後臺實時推送。如:Java,PHP, C#, Ruby, Python, C, C++, ASP.NET,Node.js...html

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

 

PHP Web實時消息後臺服務器推送技術-GoEasynode

 

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

 

1. 你須要到goeasy官網上註冊一個帳號,並建立一個應用,應用建立好後系統會默認爲它生成兩個key: publish key和subscribe keyweb

 

2. 前臺實時訂閱及接收瀏覽器

    只須要引入goeasy.js,而後調用goeasy的subscribe方法訂閱一個channel便可,訂閱時不管是用publish key仍是subscribe key均可以。經過subscribe的參數 onMessage的回調函數能夠實時接收到消息。服務器

 

3. 前臺實時推送websocket

    仍是須要引入goeasy.js(若是該頁面已經引入了可不在引入),而後調用goeasy的publish方法向已訂閱的channel上推送消息便可,推送時只能用publish key。

 

4. 後臺實時推送

     調用GoEasy Restful API, 用post方式訪問http://goeasy.io/goeasy/publish, 同時還須要帶上三個必要參數:

    appkey: publish key

    channel: 你訂閱了的channel

   content: 推送內容

 

就是這麼簡單。

下面我將以前寫的一個小實例貼出來,裏面用了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>  

 


=subsibe()"/> </body> </html> 
相關文章
相關標籤/搜索