1. 程式人生 > 程式設計 >laravel框架使用極光推送訊息操作示例

laravel框架使用極光推送訊息操作示例

本文例項講述了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',//表示離線訊息保留時長(秒)
        '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,'type' => JPushService::PUSH_TYPE_ALIAS,]);

更多關於Laravel相關內容感興趣的讀者可檢視本站專題:《Laravel框架入門與進階教程》、《php優秀開發框架總結》、《php面向物件程式設計入門教程》、《php+mysql資料庫操作入門教程》及《php常見資料庫操作技巧彙總》

希望本文所述對大家基於Laravel框架的PHP程式設計有所幫助。