**极光推送Jpush(v3)服务端PHP版本的api脚本类

简介: 关于极光推送的上一篇文章已经说明了,此处就不多说了。使用v3版本的原因是v2使用到2014年年底就停止了。点击查看上一篇的地址 http://www.dodobook.net/php/777 欢迎移步浏览。

关于极光推送的上一篇文章已经说明了,此处就不多说了。使用v3版本的原因是v2使用到2014年年底就停止了。点击查看上一篇的地址 http://www.dodobook.net/php/777 欢迎移步浏览。

昨天才开始拿到极光推送的SDK下载文档。下载地址 http://docs.jpush.cn/display/dev/Server-SDKs 看了半天也看出眉目。安装example的方法试了,各种报错。还需要vendor/autoload.php composer的支持。

后来查找各种方法能实现了。但是感觉好庞大的一个包。且想封装成为一个类,几次尝试都失败。想想v2版本一个文件实现多好啊。

自己太笨了,网上找找到相关的文档。自己稍加改动,终于实现,一个类就在后端调用了。直接上代码:

 
 
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');

//
极光推送的类 //文档见:http://docs.jpush.cn/display/dev/Push-API-v3 /***使用示例 $pushObj = new Jpush(); //组装需要的参数 //$receive = 'all'; //全部 //$receive = array('tag'=>array('2401','2588','9527')); //标签 $receive = array('alias'=>array('93d78b73611d886a74*****88497f501')); //别名 $content = '这是一个测试的推送数据....测试....Hello World...'; $m_type = 'http'; $m_txt = 'http://www.iqujing.com/'; $m_time = '600'; //离线保留时间 //调用推送,并处理 $result = $pushObj->push($receive,$content,$m_type,$m_txt,$m_time); if($result){ $res_arr = json_decode($result, true); if(isset($res_arr['error'])){ //如果返回了error则证明失败 echo $res_arr['error']['message']; //错误信息 echo $res_arr['error']['code']; //错误码 return false; }else{ //处理成功的推送...... echo '推送成功.....'; return true; } }else{ //接口调用失败或无响应 echo '接口调用失败或无响应'; return false; } ***/ class Jpush{ private $app_key = 'd7fd***********c3642fc'; //待发送的应用程序(appKey),只能填一个。 private $master_secret = 'a04**********4a80377'; //主密码 private $url = "https://api.jpush.cn/v3/push"; //推送的地址 //若实例化的时候传入相应的值则按新的相应值进行 public function __construct($app_key=null, $master_secret=null,$url=null) { if ($app_key) $this->app_key = $app_key; if ($master_secret) $this->master_secret = $master_secret; if ($url) $this->url = $url; } /* $receiver 接收者的信息 all 字符串 该产品下面的所有用户. 对app_key下的所有用户推送消息 tag(20个)Array标签组(并集): tag=>array('昆明','北京','曲靖','上海'); tag_and(20个)Array标签组(交集): tag_and=>array('广州','女'); alias(1000)Array别名(并集): alias=>array('93d78b73611d886a74*****88497f501','606d05090896228f66ae10d1*****310'); registration_id(1000)注册ID设备标识(并集): registration_id=>array('20effc071de0b45c1a**********2824746e1ff2001bd80308a467d800bed39e'); */ //$content 推送的内容。 //$m_type 推送附加字段的类型(可不填) http,tips,chat.... //$m_txt 推送附加字段的类型对应的内容(可不填) 可能是url,可能是一段文字。 //$m_time 保存离线时间的秒数默认为一天(可不传)单位为秒 public function push($receiver='all',$content='',$m_type='',$m_txt='',$m_time='86400'){ $base64=base64_encode("$this->app_key:$this->master_secret"); $header=array("Authorization:Basic $base64","Content-Type:application/json"); $data = array(); $data['platform'] = 'all'; //目标用户终端手机的平台类型android,ios,winphone $data['audience'] = $receiver; //目标用户 $data['notification'] = array( //统一的模式--标准模式 "alert"=>$content, //安卓自定义 "android"=>array( "alert"=>$content, "title"=>"", "builder_id"=>1, "extras"=>array("type"=>$m_type, "txt"=>$m_txt) ), //ios的自定义 "ios"=>array( // "alert"=>$content, "badge"=>"1", "sound"=>"default", // "extras"=>array("type"=>$m_type, "txt"=>$m_txt) ), ); //苹果自定义---为了弹出值方便调测 $data['message'] = array( "msg_content"=>$content, "extras"=>array("type"=>$m_type, "txt"=>$m_txt) ); //附加选项 $data['options'] = array( "sendno"=>time(), "time_to_live"=>$m_time, //保存离线时间的秒数默认为一天 "apns_production"=>1, //指定 APNS 通知发送环境:0开发环境,1生产环境。 ); $param = json_encode($data); $res = $this->push_curl($param,$header); if($res){ //得到返回值--成功已否后面判断 return $res; }else{ //未得到返回值--返回失败 return false; } } //推送的Curl方法 public function push_curl($param="",$header="") { if (empty($param)) { return false; } $postUrl = $this->url; $curlPost = $param; $ch = curl_init(); //初始化curl curl_setopt($ch, CURLOPT_URL,$postUrl); //抓取指定网页 curl_setopt($ch, CURLOPT_HEADER, 0); //设置header curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //要求结果为字符串且输出到屏幕上 curl_setopt($ch, CURLOPT_POST, 1); //post提交方式 curl_setopt($ch, CURLOPT_POSTFIELDS, $curlPost); curl_setopt($ch, CURLOPT_HTTPHEADER,$header); // 增加 HTTP Header(头)里的字段 curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); // 终止从服务端进行验证 curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE); $data = curl_exec($ch); //运行curl curl_close($ch); return $data; } }

http://www.dodobook.net/php/780


极光推送Jpush(v3)服务端PHP版本集成(V3版本只调用推送API)

 因为版本升级,极光推送的API也有了V3,功能也更丰富了,但是对于我们有的用户来说,我们还是只需要调用推送的API就够了。

         下载了一份PHP服务端的SDK(下载地址:http://docs.jpush.io/resources/#sdk_1),然后我看蒙了。。。我们只需要推送,研究这个,花的时间也太长了一点吧!于是就到网上收集了看看有没有人集成一个类来调用的,这个特别感谢DoDobook的一个哥们儿额,参考他的我小改动了一下 就ok了!(他的博文http://www.dodobook.net/php/780)

       这里特意提醒各位,测试成不成功记得看管理平台上面的统计信息,因为之前把apns_production参数设置成了生产环境,调用接口成功,可是却没有用户,后来改为了开发环境,就成功了。

         

以下是代码区域:

<?php
class Jpush_send extends MY_Model {
        private $app_key = ‘314**************60191‘;        //待发送的应用程序(appKey),只能填一个。
        private $master_secret = ‘ab16a***********835c8862‘;    //主密码
        private $url = "https://api.jpush.cn/v3/push";      //推送的地址
    
        //若实例化的时候传入相应的值则按新的相应值进行
        public function __construct($app_key=null, $master_secret=null,$url=null) {
            if ($app_key) $this->app_key = $app_key;
            if ($master_secret) $this->master_secret = $master_secret;
            if ($url) $this->url = $url;
        }
        //极光推送的类
        //文档见:http://docs.jpush.cn/display/dev/Push-API-v3
        
        /**组装需要的参数
            $receive = ‘all‘;//全部
            $receive = array(‘tag‘=>array(‘2401‘,‘2588‘,‘9527‘));//标签
            $receive = array(‘alias‘=>array(‘93d78b73611d886a74*****88497f501‘));//别名
            $content = ‘这是一个测试的推送数据....测试....Hello World...‘;
            $m_type = ‘http‘;
            $m_txt = ‘http://www.iqujing.com/‘;
            $m_time = ‘600‘;        //离线保留时间
        **/
        //调用推送方法
        public function send_pub($receive,$content,$m_type,$m_txt,$m_time){
            $m_type = ‘http‘;//推送附加字段的类型
            $m_txt = ‘http://www.groex.cn/‘;//推送附加字段的类型对应的内容(可不填) 可能是url,可能是一段文字。
            $m_time = ‘86400‘;//离线保留时间
            
            $message="";//存储推送状态
            $result = $this->push($receive,$content,$m_type,$m_txt,$m_time);
            if($result){
                $res_arr = json_decode($result, true);
                if(isset($res_arr[‘error‘])){                       //如果返回了error则证明失败
                    echo $res_arr[‘error‘][‘message‘];          //错误信息
                    $error_code=$res_arr[‘error‘][‘code‘];             //错误码
                        switch ($error_code) {
                            case 200:
                                $message= ‘发送成功!‘;
                                break;
                            case 1000:
                                $message= ‘失败(系统内部错误)‘;
                                break;
                            case 1001:
                                $message = ‘失败(只支持 HTTP Post 方法,不支持 Get 方法)‘;
                                break;
                            case 1002:
                                $message= ‘失败(缺少了必须的参数)‘;
                                break;
                            case 1003:
                                $message= ‘失败(参数值不合法)‘;
                                break;
                            case 1004:
                                $message= ‘失败(验证失败)‘;
                                break;
                            case 1005:
                                $message= ‘失败(消息体太大)‘;
                                break;
                            case 1008:
                                $message= ‘失败(appkey参数非法)‘;
                                break;
                            case 1020:
                                $message= ‘失败(只支持 HTTPS 请求)‘;
                                break;
                            case 1030:
                                $message= ‘失败(内部服务超时)‘;
                                break;
                            default:
                                $message= ‘失败(返回其他状态,目前不清楚额,请联系开发人员!)‘;
                                break;
                        }
                }else{
                    $message="发送成功!";
                }
            }else{      //接口调用失败或无响应
                $message=‘接口调用失败或无响应‘;
            }
            echo  "<script>alert(‘推送信息:{$message}‘)</script>";
        }
        
    
        /*  $receiver 接收者的信息
         all 字符串 该产品下面的所有用户. 对app_key下的所有用户推送消息
        tag(20个)Array标签组(并集): tag=>array(‘昆明‘,‘北京‘,‘曲靖‘,‘上海‘);
        tag_and(20个)Array标签组(交集): tag_and=>array(‘广州‘,‘女‘);
        alias(1000)Array别名(并集): alias=>array(‘93d78b73611d886a74*****88497f501‘,‘606d05090896228f66ae10d1*****310‘);
        registration_id(1000)注册ID设备标识(并集): registration_id=>array(‘20effc071de0b45c1a**********2824746e1ff2001bd80308a467d800bed39e‘);
        */
        //$content 推送的内容。
        //$m_type 推送附加字段的类型(可不填) http,tips,chat....
        //$m_txt 推送附加字段的类型对应的内容(可不填) 可能是url,可能是一段文字。
        //$m_time 保存离线时间的秒数默认为一天(可不传)单位为秒
        public function push($receiver=‘all‘,$content=‘‘,$m_type=‘‘,$m_txt=‘‘,$m_time=‘86400‘){
            $base64=base64_encode("$this->app_key:$this->master_secret");
            $header=array("Authorization:Basic $base64","Content-Type:application/json");
            $data = array();
            $data[‘platform‘] = ‘all‘;          //目标用户终端手机的平台类型android,ios,winphone
            $data[‘audience‘] = $receiver;      //目标用户
             
            $data[‘notification‘] = array(
                    //统一的模式--标准模式
                    "alert"=>$content,
                     //安卓自定义
                    "android"=>array(
                            "alert"=>$content,
                            "title"=>"",
                            "builder_id"=>1,
                            "extras"=>array("type"=>$m_type, "txt"=>$m_txt)
                    ),
                    //ios的自定义
                    "ios"=>array(
                             "alert"=>$content,
                            "badge"=>"1",
                            "sound"=>"default",
                             "extras"=>array("type"=>$m_type, "txt"=>$m_txt)
                    )
            );
    
            //苹果自定义---为了弹出值方便调测
            $data[‘message‘] = array(
                    "msg_content"=>$content,
                    "extras"=>array("type"=>$m_type, "txt"=>$m_txt)
            );
    
            //附加选项
            $data[‘options‘] = array(
                    "sendno"=>time(),
                    "time_to_live"=>$m_time, //保存离线时间的秒数默认为一天
                    "apns_production"=>false, //布尔类型   指定 APNS 通知发送环境:0开发环境,1生产环境。或者传递false和true
            );
            $param = json_encode($data);
            $res = $this->push_curl($param,$header);
             
            if($res){       //得到返回值--成功已否后面判断
                return $res;
            }else{          //未得到返回值--返回失败
                return false;
            }
        }
    
        //推送的Curl方法
        public function push_curl($param="",$header="") {
            if (empty($param)) { return false; }
            $postUrl = $this->url;
            $curlPost = $param;
            $ch = curl_init();                                      //初始化curl
            curl_setopt($ch, CURLOPT_URL,$postUrl);                 //抓取指定网页
            curl_setopt($ch, CURLOPT_HEADER, 0);                    //设置header
            curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);            //要求结果为字符串且输出到屏幕上
            curl_setopt($ch, CURLOPT_POST, 1);                      //post提交方式
            curl_setopt($ch, CURLOPT_POSTFIELDS, $curlPost);
            curl_setopt($ch, CURLOPT_HTTPHEADER,$header);           // 增加 HTTP Header(头)里的字段
            curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);        // 终止从服务端进行验证
            curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
            $data = curl_exec($ch);                                 //运行curl
            curl_close($ch);
            return $data;
        }
    
}
?>

 

如何联系我:【万里虎】www.bravetiger.cn 【QQ】3396726884 (咨询问题100元起,帮助解决问题500元起) 【博客】http://www.cnblogs.com/kenshinobiy/
目录
相关文章
|
3月前
|
API 索引
String类下常用API
String类下常用API
42 1
|
3月前
|
安全 Java API
告别繁琐编码,拥抱Java 8新特性:Stream API与Optional类助你高效编程,成就卓越开发者!
【8月更文挑战第29天】Java 8为开发者引入了多项新特性,其中Stream API和Optional类尤其值得关注。Stream API对集合操作进行了高级抽象,支持声明式的数据处理,避免了显式循环代码的编写;而Optional类则作为非空值的容器,有效减少了空指针异常的风险。通过几个实战示例,我们展示了如何利用Stream API进行过滤与转换操作,以及如何借助Optional类安全地处理可能为null的数据,从而使代码更加简洁和健壮。
106 0
|
2天前
|
XML JSON API
【PHP开发专栏】PHP RESTful API设计与开发
随着互联网技术的发展,前后端分离成为Web开发的主流模式。本文介绍RESTful API的基本概念、设计原则及在PHP中的实现方法。RESTful API是一种轻量级、无状态的接口设计风格,通过HTTP方法(GET、POST、PUT、DELETE)操作资源,使用JSON或XML格式传输数据。在PHP中,通过定义路由、创建控制器、处理HTTP请求和响应等步骤实现RESTful API,并强调了安全性的重要性。
9 2
|
1天前
|
JSON API PHP
如何使用PHP开发API接口?
本文详细介绍了如何使用PHP开发API接口,涵盖从基础概念到实战步骤的全过程。首先解释了API接口的基本原理,包括HTTP协议、REST架构风格、JSON格式和OAuth认证机制。接着介绍了开发环境的设置,包括PHP安装、Web服务器配置、数据库设置等。文章还探讨了API开发的完整流程,从需求确定、框架选择、端点设计到代码编写、测试、安全性考量及性能优化。最后通过一个实战案例演示了如何创建一个简单的API端点,并讨论了部署与监控的方法。
10 0
|
1月前
|
设计模式 SQL 安全
PHP中的设计模式:单例模式的深入探索与实践在PHP开发领域,设计模式是解决常见问题的高效方案集合。它们不是具体的代码,而是一种编码和设计经验的总结。单例模式作为设计模式中的一种,确保了一个类仅有一个实例,并提供一个全局访问点。本文将深入探讨单例模式的基本概念、实现方式及其在PHP中的应用。
单例模式在PHP中的应用广泛,尤其在处理数据库连接、日志记录等场景时,能显著提高资源利用率和执行效率。本文从单例模式的定义出发,详细解释了其在PHP中的不同实现方法,并探讨了使用单例模式的优势与注意事项。通过对示例代码的分析,读者将能够理解如何在PHP项目中有效应用单例模式。
|
2月前
|
IDE 安全 网络安全
Xdebug 在不同版本的 PHP 中配置方法有什么不同?
Xdebug 在不同版本的 PHP 中配置方法有什么不同?
155 4
|
2月前
|
设计模式 SQL 安全
PHP中的设计模式:单例模式的深入探索与实践在PHP的编程实践中,设计模式是解决常见软件设计问题的最佳实践。单例模式作为设计模式中的一种,确保一个类只有一个实例,并提供全局访问点,广泛应用于配置管理、日志记录和测试框架等场景。本文将深入探讨单例模式的原理、实现方式及其在PHP中的应用,帮助开发者更好地理解和运用这一设计模式。
在PHP开发中,单例模式通过确保类仅有一个实例并提供一个全局访问点,有效管理和访问共享资源。本文详细介绍了单例模式的概念、PHP实现方式及应用场景,并通过具体代码示例展示如何在PHP中实现单例模式以及如何在实际项目中正确使用它来优化代码结构和性能。
44 2
|
2月前
|
PHP
PHP中的面向对象编程:理解类与对象
本文将深入探讨PHP中面向对象编程的核心概念——类与对象。通过实例讲解,帮助读者更好地理解如何在PHP中运用OOP编写更高效、可维护的代码。
43 9
|
1月前
|
API
使用`System.Net.WebClient`类发送HTTP请求来调用阿里云短信API
使用`System.Net.WebClient`类发送HTTP请求来调用阿里云短信API
21 0
|
2月前
|
Java API 开发者
【Java字节码操控新篇章】JDK 22类文件API预览:解锁Java底层的无限可能!
【9月更文挑战第6天】JDK 22的类文件API为Java开发者们打开了一扇通往Java底层世界的大门。通过这个API,我们可以更加深入地理解Java程序的工作原理,实现更加灵活和强大的功能。虽然目前它还处于预览版阶段,但我们已经可以预见其在未来Java开发中的重要地位。让我们共同期待Java字节码操控新篇章的到来!