Blogger Information
Blog 263
fans 3
comment 2
visits 113692
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
使用GoEasy实现web实时消息推送
福哥的博客
Original
2997 people have browsed it

越来越多的项目需要用到实时消息的推送与接收,怎样用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;运用十分简单!


 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. 浏览器兼容性如何
除了常用的浏览器chrome, firefox, safari, opera外还支持IE 6到IE11的版本,低版本IE浏览器GoEasy采用的是polling的方式。GoEasy在兼容性这方面做的很不错。
4. 产品的稳定性和安全性
稳定性的判定:项目已经持续运行了4个月了,没有出现过消息推不出或接收不到的情况。
安全性的判定:GoEasy在安全控制方面主要是通过appkey来控制,创建好app后系统会生成两个key,一个既可以用来接收又可以用来推送,另一个只可以用来接收。所以用户可以选择性的暴露你的key.
这样轻松用PHP实现客户端与服务器端的实时通信了

Statement of this Website
The copyright of this blog article belongs to the blogger. Please specify the address when reprinting! If there is any infringement or violation of the law, please contact admin@php.cn Report processing!
All comments Speak rationally on civilized internet, please comply with News Comment Service Agreement
0 comments
Author's latest blog post