orhan-proven / laravel-push-notification
此包最新版本(dev-master)无可用许可证信息。
Laravel 包,用于向移动设备发送推送通知(apns, gcm)
dev-master
2015-10-08 07:10 UTC
Requires
- php: >=5.3.0
- illuminate/support: 4.*
- orhan-proven/notification-pusher: 2.*
This package is not auto-updated.
Last update: 2024-10-02 10:24:52 UTC
README
使设备能够发送推送通知的包
安装
更新你的 composer.json
文件,将其作为依赖项包含
Laravel 5 & Lumen
"davibennun/laravel-push-notification": "dev-laravel5"
Laravel 4.*
"davibennun/laravel-push-notification": "dev-master"
通过将其添加到 providers 数组中注册 PushNotification 服务提供者。
'providers' => array( ... 'Davibennun\LaravelPushNotification\LaravelPushNotificationServiceProvider' )
在 app/config/app.php
文件的 aliases 数组中添加别名 PushNotification 门面。
'aliases' => array( ... 'PushNotification' => 'Davibennun\LaravelPushNotification\Facades\PushNotification' )
配置
通过运行以下命令将配置文件复制到你的项目中:(Lumen 用户跳过此步骤)
Laravel 5
php artisan vendor:publish --provider="Davibennun\LaravelPushNotification\LaravelPushNotificationServiceProvider" --tag="config"
Laravel 4.*
php artisan config:publish davibennun/laravel-push-notification
这将生成一个类似以下配置文件
array( 'appNameIOS'=>array( 'environment' => 'development', 'certificate' => '/path/to/certificate.pem', 'passPhrase' => 'password', 'service' => 'apns' ), 'appNameAndroid'=>array( 'environment' => 'production', 'apiKey' => 'yourAPIKey', 'service' => 'gcm' ) );
其中所有一级键对应一个服务配置,每个服务都有自己的属性,例如 Android 有 apiKey
,iOS 使用 certificate
和 passPhrase
。你可以设置任意多的服务配置,每个应用一个。
别忘了设置 service
键来识别 iOS 'service'=>'apns'
和 Android 'service'=>'gcm'
证书路径必须是绝对路径,所以在配置文件中你可以使用这些
//Path to the 'app' folder
'certificate'=>app_path().'/myCert.pem'
Laravel 函数也可用 public_path()
storage_path()
base_path()
用法
PushNotification::app('appNameIOS') ->to($deviceToken) ->send('Hello World, i`m a push message');
其中 app 参数 appNameIOS
指的是配置文件中定义的服务。
### 动态配置和 Lumen 用户 你可以直接设置 app 配置数组:(注意数组结构)
//iOS app PushNotification::app(['environment' => 'development', 'certificate' => '/path/to/certificate.pem', 'passPhrase' => 'password', 'service' => 'apns']); //Android app PushNotification::app(['environment' => 'production', 'apiKey' => 'yourAPIKey', 'service' => 'gcm']);
向多个设备和可选消息
$devices = PushNotification::DeviceCollection(array( PushNotification::Device('token', array('badge' => 5)), PushNotification::Device('token1', array('badge' => 1)), PushNotification::Device('token2') )); $message = PushNotification::Message('Message Text',array( 'badge' => 1, 'sound' => 'example.aiff', 'actionLocKey' => 'Action button title!', 'locKey' => 'localized key', 'locArgs' => array( 'localized args', 'localized args', ), 'launchImage' => 'image.jpg', 'custom' => array('custom data' => array( 'we' => 'want', 'send to app' )) )); $collection = PushNotification::app('appNameIOS') ->to($devices) ->send($message); // get response for each device push foreach ($collection->pushManager as $push) { $response = $push->getAdapter()->getResponse(); } // access to adapter for advanced settings $push = PushNotification::app('appNameAndroid'); $push->adapter->setAdapterParameters(['sslverifypeer' => false]);
此包封装了 Notification Package 并添加了一些功能。
使用建议
建议与 Laravel Queues 一起使用此包,这样推送不会阻塞用户,而是在后台处理,意味着更好的流程。