php免费接入极光推送
程序员文章站
2022-06-22 19:06:03
php免费接入极光推送步骤:极光账号配置项目引入极光SDK,以thinkphp5为例实现推送:1、实现推送首先要先将用户的应用id(应用id要更新,一个用户只允许有一个)与极光registration_id绑定,这样才能知道推送给谁极光。2、编写推送类。3、实现推送。官方github SDK:https://github.com/jpush/jpush-api-php-client1、账号配置:极光官网: https://www.jiguang.cn/创建应用:配置安卓应用包名:...
php免费接入极光推送
步骤:
- 极光账号配置
- 项目引入极光SDK,以thinkphp5为例
- 实现推送:1、实现推送首先要先将用户的应用id(应用id要更新,一个用户只允许有一个)与极光registration_id绑定,这样才能知道推送给谁极光。2、编写推送类。3、实现推送。
官方github SDK:
https://github.com/jpush/jpush-api-php-client
1、账号配置:
极光官网: https://www.jiguang.cn/
创建应用:
配置安卓应用包名:
配置ios证书:
2、下载sdk引入项目
我是用composer,项目为thinkphp5框架,直接执行:
composer require jpush/jpush
检查是否已经引入:
3、编写推送类实现推送:
- 用户绑定极光推送id
/**
* desc 用户绑定极光推送唯一标识id
*/
public function addBindJpush()
{
$json = $this->request->param();
$params = json_decode($json['data'], true);
$params['uid'] = $this->uid;
// 判断是安卓还是ios
$platform = $json['_platform'];
$type_ = 1;
if ($platform == 'android') {
$type_ = 1;
} elseif ($platform == 'ios') {
$type_ = 2;
}
if (empty($params['registration_id']) || empty($params['uid'])) {
throw new Exception(10009);
}
$info = UserJpush::where(['uid' => $params['uid']])->find();
if (!empty($info)) {
if ($info['registration_id'] != $params['registration_id']) {
UserJpush::where(['uid' => $params['uid']])->update(['registration_id' => $params['registration_id'], 'type' => $type_, 'up_time' => date('Y-m-d H:i:s')]);
}
$this->returnmsg(200, 'success', []);
} else {
// 添加绑定
$res = UserJpush::create([
'uid' => $params['uid'],
'registration_id' => $params['registration_id'],
'add_time' => date('Y-m-d H:i:s'),
'type' => $type_,
]);
$this->returnmsg(200, 'success', $res);
}
}
- JPush.php内容
<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2018/3/7 0007
* Time: 14:04
*/
namespace Api;
use app\common\model\UserJpush;
use think\Exception;
use JPush\Client;
class JPush{
/**
* 极光推送
* @param int $type 1安卓 2 ios
* @param string $title 标题
* @param string $push_type 推送类型:1全部,2 registration_id ,3 别名
* @param string $message_content 内容
* @param array $data 推送目标,例如:1为 all,2为用户id[ 122 ,123 ],3为别名id数组[]
* @param int $item_id 扩展id
* @return mixed
*/
public static function push($type = 1,$title,$message_content,$push_type = 2,$data,$item_id = 0){
if(empty($title)) return false;
$config_private = \config('jpush_config');
$app_key = $type == 1 ? $config_private['and_jpush_key'] : $config_private['ios_jpush_key'];
$master_secret = $type == 1 ? $config_private['and_jpush_secret'] : $config_private['ios_jpush_secret'];
$client = new Client($app_key, $master_secret);
if ($push_type == 1){
$data = 'all';
}elseif ($push_type == 2){
$list = UserJpush::where(['uid'=>['in',$data]])->select()->toArray();
$data = [];
if ($list){
$data = array_unique(array_column($list,'registration_id'));
}
}else{
return true;
}
try {
$client = $client->push()->setPlatform(array('ios', 'android'));
if ($push_type == 1){
$client = $client->addAllAudience($data);
}elseif ($push_type == 2){
$client = $client->addRegistrationId($data);
}
// 一般情况下,关于 audience 的设置只需要调用 addAlias、addTag、addTagAnd 或 addRegistrationId
// 这四个方法中的某一个即可,这里仅作为示例,当然全部调用也可以,多项 audience 调用表示其结果的交集
// 即是说一般情况下,下面三个方法和没有列出的 addTagAnd 一共四个,只适用一个便可满足大多数的场景需求
// ->addAlias($alias)
// ->addTag(array('tag1', 'tag2'))
// ->addAllAudience()
$res = $client->setNotificationAlert($title)
->iosNotification(['title'=>$title,'body'=>$message_content], array(
'sound' => 'sound.caf',
// 'badge' => '+1',
// 'content-available' => true,
// 'mutable-content' => true,
'extras' => array(
'id' => $item_id,
),
))
->androidNotification($title, array(
'title' => $message_content,
// 'builder_id' => 2,
'extras' => array(
'id' => $item_id,
),
))
->message($message_content, array(
'title' => $title,
// 'content_type' => 'text',
'extras' => array(
'id' => $item_id,
),
))
->options(array(
// sendno: 表示推送序号,纯粹用来作为 API 调用标识,
// API 返回时被原样返回,以方便 API 调用方匹配请求与返回
// 这里设置为 100 仅作为示例
// 'sendno' => 100,
// time_to_live: 表示离线消息保留时长(秒),
// 推送当前用户不在线时,为该用户保留多长时间的离线消息,以便其上线时再次推送。
// 默认 86400 (1 天),最长 10 天。设置为 0 表示不保留离线消息,只有推送当前在线的用户可以收到
// 这里设置为 1 仅作为示例
// 'time_to_live' => 1,
// apns_production: 表示APNs是否生产环境,
// True 表示推送生产环境,False 表示要推送开发环境;如果不指定则默认为推送开发环境
'apns_production' => true,
// big_push_duration: 表示定速推送时长(分钟),又名缓慢推送,把原本尽可能快的推送速度,降低下来,
// 给定的 n 分钟内,均匀地向这次推送的目标用户推送。最大值为1400.未设置则不是定速推送
// 这里设置为 1 仅作为示例
// 'big_push_duration' => 1
))
->setSmsMessage(array(
'delay_time' => 60,
'signid' => 154,
'temp_id' => 1,
'temp_para' => array(
'code' => 357
),
'active_filter' => false
))
->send();
} catch (Exception $e) {
// try something else here
$ress['code'] = $e->getCode();
$ress['msg'] = $e->getMessage();
$data = ['data'=>$data,'res'=>$ress];
add_debug_log($data,'addJpush','推送失败');
}
return true;
}
}
- 添加公共方法,方便调用推送:
/**
* 极光推送
* @param int $type 1安卓 2 ios
* @param string $title 标题
* @param string $push_type 推送类型:1全部,2 registration_id ,3 别名
* @param string $message_content 内容
* @param array $data 推送目标,例如:1为 all,2为用户id[ 122 ,123 ],3为别名id数组[]
* @param int $item_id 扩展id
* @return mixed
* * 例如:addJpush(2,'测试-标题2','测试推送-内容',2,['110134','7232'],'6547');
*/
function addJpush($type = 1,$title,$message_content,$push_type = 2,$data,$item_id = 0){
$push_res = JPush::push( $type,$title,$message_content,$push_type,$data,$item_id);
return $push_res;
}
- 执行推送,一行代码:
addJpush(2, '认证通过通知', '恭喜您已提交认证...', 2, [$uid], $uid);
end
本文地址:https://blog.csdn.net/u013367684/article/details/107499118