博客列表 >使用GoEasy实现web实时消息推送

使用GoEasy实现web实时消息推送

福哥的博客
福哥的博客原创
2017年10月18日 19:53:572985浏览

越来越多的项目需要用到实时消息的推送与接收,怎样用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实现客户端与服务器端的实时通信了

上一条:MySQL语句下一条:PHPstorm汉化
声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议