本文实例讲述了laravel框架使用极光推送消息。分享给大家供大家参考,具体如下:
最近需要使用极光推送往客户端推消息,所以这里记录下使用过程。
极光推送的服务端文档:
https://docs.jiguang.cn/jpush/server/push/server_overview/
极光推送服务端PHP代码:
https://github.com/jpush/jpush-api-php-client
在laravel项目下安装极光推送
composer require jpush/jpush
我们在config目录下创建一个jpush.php文件,用于获取key和secret
<?php return [ 'app_key' => env('JPUSH_APP_KEY', ''), 'master_secret' => env('JPUSH_MASTER_SECRET', ''), 'apns_production' => env('JPUSH_APNS_PRODUCTION', true), ];
然后在 .env 文件中配置相应参数
JPUSH_APP_KEY= JPUSH_MASTER_SECRET= JPUSH_APNS_PRODUCTION=true
然后我们在app目录下,创建一个 Services目录,并创建JPushService.php
<?php namespace App\Services; use JPush\Client as JPush; use Log; class JPushService { protected static $client = null; //推送类型 const PUSH_TYPE_ALL = 1; const PUSH_TYPE_TAG = 2; const PUSH_TYPE_ALIAS = 3; const PUSH_TYPE_REG_ID = 4; private function __construct() { } private function __clone() { } /** * 获取实例 */ public static function getInstance() { if (!self::$client) { self::$client = new JPush(config('jpush.app_key'), config('jpush.master_secret'), null); } return self::$client; } /** * 给android或ios推送消息 */ public static function pushNotify($params) { //推送平台 $platform = $params['platform'] ?? 'all'; //推送标题 $title = $params['title'] ?? ''; //推送内容 $content = $params['content'] ?? ''; //通知栏样式ID $builder_id = $params['builder_id'] ?? 0; //附加字段 $extras = $params['extras'] ?? ''; //推送类型 $type = $params['type'] ?? ''; //推送目标(注册ID) $reg_id = $params['reg_id'] ?? ''; //推送目标(标签) $tag = $params['tag'] ?? ''; //推送目标(别名) $alias = $params['alias'] ?? ''; try { $push = self::getInstance()->push(); //设置平台 $push->setPlatform($platform); switch ($type) { case self::PUSH_TYPE_ALL: $push->addAllAudience(); break; case self::PUSH_TYPE_TAG: $push->addTag($tag); break; case self::PUSH_TYPE_ALIAS: $push->addAlias($alias); break; case self::PUSH_TYPE_REG_ID: $push->addRegistrationId($reg_id); break; } $push->androidNotification($content, [ 'title' => $title, 'builder_id' => $builder_id, 'extras' => $extras, ])->iosNotification($content, [ 'sound' => 'sound', 'badge' => '+1', 'extras' => $extras ])->options([ 'apns_production' => config('jpush.apns_production', true), //表示离线消息保留时长(秒) 'time_to_live' => 86400, ]); $response = $push->send(); if ($response['http_code'] != 200) { Log::channel('jpush')->error(json_encode($response, JSON_UNESCAPED_UNICODE)); } return $response; } catch (\Throwable $e) { Log::channel('jpush')->error(json_encode([ 'file' => $e->getFile(), 'line' => $e->getLine(), 'message' => $e->getMessage(), 'params' => $params, ], JSON_UNESCAPED_UNICODE)); } } /** * 获取指定设备的别名和标签 */ public static function getDevices($reg_id) { $response = self::getInstance()->device()->getDevices($reg_id); if ($response['http_code'] == 200) { return $response['body']; } return []; } /** * 给指定设备添加标签 */ public static function addTags($reg_id, $tags = []) { $response = self::getInstance()->device()->addTags($reg_id, $tags); if ($response['http_code'] == 200) { return true; } return false; } /** * 清空指定设备的标签 */ public static function clearTags($reg_id) { $response = self::getInstance()->device()->clearTags($reg_id); if ($response['http_code'] == 200) { return true; } return false; } /** * 清空指定设备的标签 */ public static function removeTags($reg_id, $tags = []) { $response = self::getInstance()->device()->removeTags($reg_id, $tags); if ($response['http_code'] == 200) { return true; } return false; } /** * 更新指定设备的别名 */ public static function updateAlias($reg_id, $alias) { $response = self::getInstance()->device()->updateAlias($reg_id, $alias); if ($response['http_code'] == 200) { return true; } return false; } }
创建完后,我们就可以在项目中调用 JPushService::pushNotify() 来推消息了。
JPushService::pushNotify([ //标题 'title' => '测试', //内容 'content' => '测试', //设备标识,跟设备相关 'reg_id' => 'xxxxxxxxxxx', //扩展字段 'extras' => [ 'key' => 'value', ], //推送类型 'type' => JPushService::PUSH_TYPE_REG_ID, ]);
reg_id是前端安卓或IOS获取到后,传给PHP后端,然后跟用户关联,存起来。
注意,reg_id是跟设备相关的,同一个设备上的APP,当不同用户登陆时,reg_id是一样的,这样会导致一个问题。
A用户登APP后,又切换到B用户,那B用户会收到发送给A用户的消息,这会造成消息错乱。
解决方法:
通过别名来发送消息,因为一个设备只能绑定一个别名,当A用户登陆时,把 reg_id 绑定到别名 user_a,切换用户或退出时,就把别名置空。
然后B用户登陆,就把 reg_id 绑定到 user_b 上。推消息时,就通过别名来推送消息。
绑定别名(推荐使用用户ID来区分不同的别名):
JPushService::updateAlias($user->jpush_reg_id, 'user_id_' . $user->id);
置空别名:
JPushService::updateAlias($user->jpush_reg_id, '');
通过别名发送:
JPushService::pushNotify([ 'title' => '测试', 'content' => '测试', 'alias' => 'user_id_' . $message->receive_id, 'extras' => $extras, 'type' => JPushService::PUSH_TYPE_ALIAS, ]);
更多关于Laravel相关内容感兴趣的读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。
本文向大家介绍laravel框架使用阿里云短信发送消息操作示例,包括了laravel框架使用阿里云短信发送消息操作示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了laravel框架使用阿里云短信发送消息操作。分享给大家供大家参考,具体如下: 最新需要用到发送短信的功能,所以就在网上搜索一些写好的扩展。 扩展地址: https://github.com/MissMyCat/aliyun-
本文向大家介绍Yii1.1框架实现PHP极光推送消息通知功能,包括了Yii1.1框架实现PHP极光推送消息通知功能的使用技巧和注意事项,需要的朋友参考一下 一、下载极光推送PHP SDK,解压后放在/protected/components/目录下,如下图所示: 二、完善修改下官方的demo例子,我这里复制一份demo,改为NotifyPush.php,如下代码: 三、调用NotifyPush.p
一、基础配置 第一步:创建极光账号 如没有极光账号,需要创建极光推送账号及应用,获得AppKey和Master Secret 两个参数。如下图所示: 第二步:在智能触达中配置极光账号 在诸葛「智能触达→设置→触达渠道→推送消息」中,找到「极光推送」,填入上一步中得到的AppKey和Master Secret参数并完成开通。 第三步:确认SDK中添加推送逻辑代码 实现推送功能,需要SDK从客户端获得
我们在开发针对国内运营的时候进行需要使用过程的几家推送,极光推送则是其中之一。这个包就可以让你方便地在你构建的 Laravel 应用中进行极光推送的使用。 前提 PHP >= 7 Laravel >= 5.5 安装 在 Laravel 应用目录使用 Composer 进行依赖: composer require medz/laravel-jpush-notification-channel 包中依
本文向大家介绍android studio集成极光推送的操作步骤,包括了android studio集成极光推送的操作步骤的使用技巧和注意事项,需要的朋友参考一下 之前使用的是小米推送,感觉还不错,集成简单,这次使用极光推送,看文档,很多用不到的东西看的好乱,所以这次记录: 第一、在极光配置信息,我是因为iso先创建应用了,我直接配置自己的信息就行,就填写一个包名。 第二、build.gradle
本文向大家介绍php 使用ActiveMQ发送消息,与处理消息操作示例,包括了php 使用ActiveMQ发送消息,与处理消息操作示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了php 使用ActiveMQ发送消息,与处理消息操作。分享给大家供大家参考,具体如下: 我们以一个简单的用户注册为例,当用户点击注册按钮后,我们发送一个消息,后台php接收到该消息然后处理。 1.php代码如下