我们在开发针对国内运营的时候进行需要使用过程的几家推送,极光推送则是其中之一。这个包就可以让你方便地在你构建的 Laravel 应用中进行极光推送的使用。
在 Laravel 应用目录使用 Composer 进行依赖:
composer require medz/laravel-jpush-notification-channel
包中依赖了匹配的 jpush/jpush 依赖版本为 ^3.6,你已经依赖了更低版本的不兼容版本包,使用的时候要小心了!
在 config/services.php 中进行如下配置:
return [
'jpush' => [
'app_key' => env('JPUSH_APP_KEY', ''),
'master_secret' => env('JPUSH_MASTER_SECRET', ''),
'apns_production' => env('JPUSH_APNS_PRODUCTION', false),
],
];
然后在 .env 文件中进行配置:
JPUSH_APP_KEY=
JPUSH_MASTER_SECRET=
JPUSH_APNS_PRODUCTION=
首先,要在数据模型上添加一个 routeNotificationForJpush 方法:
use Illuminate\Foundation\Auth\User as Authenticatable;
use Medz\Laravel\Notifications\JPush\Sender as JPushSender;
class User extends Authenticatable
{
/**
* Get Notification for JPush sender.
* @return \Medz\Laravel\Notifications\JPush\Sender
*/
protected function routeNotificationForJpush()
{
return new JPushSender([
'platform' => 'all',
'audience' => [
'alias' => sprintf('user_%d', $this->id),
],
]);
}
}
这里我们返回一个 Medz\Laravel\Notifications\JPush\Sender 实例,可以使用构造参数快速配置,如同上面一样,也可以使用链式调用进行配置。链式调用的 API 如下:
setPlatform
设置平台,值有 all、winphone、android 和 iossetAudience
推送目标进行设置setAudience 方法或者构造参数中的 audience 设置参考:推送目标文档。
然后打开通知类,添加一个toJpush
方法,这里我们已app/Notifications/CommentNotification.php
为例:
<?php
namespace App\Notifications;
use Illuminate\Notifications\Notification;
use Medz\Laravel\Notifications\JPush\Message as JPushMessage;
class CommentNotification extends Notification
{
public function toJpush($notifiable)
{
$message = new JPushMessage();
// TODO
/*
====== 把所有的配置都进行配置 ===
$message->setAlert('Alert.'); // 简单地给所有平台推送相同的 alert 消息
// 自定义消息
$message->setMessage('Message', [
'title' => '', // 通知标题,会填充到 toast 类型 text1 字段上
'_open_page' => '', 点击打开的页面名称
'extras' => [], // 自定义的数据内容
]);
// iOS 通知
$message->setNotification(JPushMessage::IOS, 'Alert 内容', [
'alert' => '', // 覆盖第二个参数的 Alert 内,推荐不传,
'sound' => '', // 表示通知提示声音,默认填充为空字符串
'badge' => '', // 表示应用角标,把角标数字改为指定的数字;为 0 表示清除,支持 '+1','-1' 这样的字符串,表示在原有的 badge 基础上进行增减,默认填充为 '+1'
/// ...
])
// 更多通知请参考 https://docs.jiguang.cn/jpush/server/push/rest_api_v3_push/#notification 官方文档
// 使用 `setNotification` 方法第一个常量有三个: IOS/ANDROID/WP
// 可选参数
$message->setOptions([]); // 参考 https://docs.jiguang.cn/jpush/server/push/rest_api_v3_push/#options
*/
return $message;
}
}
toJpush
方法需要返回一个Medz\Laravel\Notifications\JPush\Message
对象实例!
完成上面的配置后,就可以推送了,记得在 via
方法中返回 jpush
这个值哈,例如:
public function via()
{
return ['database', 'jpush'];
}
一、基础配置 第一步:创建极光账号 如没有极光账号,需要创建极光推送账号及应用,获得AppKey和Master Secret 两个参数。如下图所示: 第二步:在智能触达中配置极光账号 在诸葛「智能触达→设置→触达渠道→推送消息」中,找到「极光推送」,填入上一步中得到的AppKey和Master Secret参数并完成开通。 第三步:确认SDK中添加推送逻辑代码 实现推送功能,需要SDK从客户端获得
消息推送在APP应用中越来越普遍,来记录一下项目中用到的一种推送方式,对于Andriod它并没有自己的原生推送机制,一种简单的推送方式是采用第三方推送服务的方式,即通过嵌入SDK使用第三方提供的推送服务,主流的有百度云推送,极光推送,友盟,个推、亚马逊等等。本篇博文只介绍采用极光推送的方式。
本文向大家介绍laravel框架使用极光推送消息操作示例,包括了laravel框架使用极光推送消息操作示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了laravel框架使用极光推送消息。分享给大家供大家参考,具体如下: 最近需要使用极光推送往客户端推消息,所以这里记录下使用过程。 极光推送的服务端文档: https://docs.jiguang.cn/jpush/server/push
如果发布极光推送官方更新了新的插件,我们如何将WeX5中使用的极光推送插件更新呢? 答案很简单,只需要按以下步骤进行即可: 1. 去https://github.com/jpush/jpush-phonegap-plugin下载最新版的cordova插件 2. 修改文件夹的名字为插件的id即:cn.jpush.phonegap.JPushPlugin 3. 将原来插件中的plugin-ex.xml
本文向大家介绍Yii1.1框架实现PHP极光推送消息通知功能,包括了Yii1.1框架实现PHP极光推送消息通知功能的使用技巧和注意事项,需要的朋友参考一下 一、下载极光推送PHP SDK,解压后放在/protected/components/目录下,如下图所示: 二、完善修改下官方的demo例子,我这里复制一份demo,改为NotifyPush.php,如下代码: 三、调用NotifyPush.p
本文向大家介绍Android 极光推送别名与标签方式,包括了Android 极光推送别名与标签方式的使用技巧和注意事项,需要的朋友参考一下 Android 极光推送 别名、标签、RegistrationID 说明 别名(alias) 为安装了应用程序的用户,取个别名来标识。以后给该用户 Push 消息时,就可以用此别名来指定。每个用户只能指定一个别名。 建议:对于同一个应用内部,建议不同用户设置不