Cordova极光推送相关配置

作者: Nickyzhang | 来源:发表于2017-04-08 21:10 被阅读672次

准备材料

  • 首先去极光官网注册账号并创建应用
  • 下载Cordova推送插件并按照说明进行添加插件配置
  • iOS推送证书(开发环境和生产环境)
  • iOS打包证书和描述文件
  • 在plugin.xml和JPushConfig.plist文件中配置相应的App_key和包名

代码说明

创建自定义service

angular.module('JPushServiceModule', [])
  .factory('jPushService', function ($window, publicMethod) {
    var jpushServiceFactory = {};

    //启动极光推送
    var _init = function (config) {
      $window.plugins.jPushPlugin.init();
      /*
       * 设置tag和Alias触发事件处理
       * */
      document.addEventListener('jpush.setAlias', config.stac, false);
      document.addEventListener("jpush.openNotification", onOpenNotification, false);
      /*
       * 打开推送消息事件处理
       * */
      $window.plugins.jPushPlugin.openNotificationInAndroidCallback = config.oniac;
      $window.plugins.jPushPlugin.receiveNotificationIniOSCallback = config.onios;
      $window.plugins.jPushPlugin.setDebugMode(true);
    };
    var onOpenNotification = function (event) {
      try {
        publicMethod.goView('my-message');
      } catch (exception) {
      }
    };
    /*
     * 获取状态
     * */
    var _isPushStopped = function (fun) {
      $window.plugins.jPushPlugin.isPushStopped(fun);
    };
    /*
     * 停止极光推送
     * */
    var _stopPush = function () {
      $window.plugins.jPushPlugin.stopPush();
    };
    /*
     * 重启极光推送
     * */
    var _resumePush = function () {
      $window.plugins.jPushPlugin.resumePush();
    };
    /*
     * 设置标签和别名
     * */
    var _setTagsWithAlias = function (tags, alias) {
      $window.plugins.jPushPlugin.setTagsWithAlias(tags, alias);
    };
    /*
     * 设置标签
     * */
    var _setTags = function (tags) {
      $window.plugins.jPushPlugin.setTags(tags);
    };
    /*
     * 设置别名
     * */
    var _setAlias = function (alias) {
      $window.plugins.jPushPlugin.setAlias(alias);
    };
    /*
     * 清除角标
     * */
    var _resetBadge = function () {
      $window.plugins.jPushPlugin.resetBadge();
    };

    jpushServiceFactory.init = _init;
    jpushServiceFactory.isPushStopped = _isPushStopped;
    jpushServiceFactory.stopPush = _stopPush;
    jpushServiceFactory.resumePush = _resumePush;
    jpushServiceFactory.setTagsWithAlias = _setTagsWithAlias;
    jpushServiceFactory.setTags = _setTags;
    jpushServiceFactory.setAlias = _setAlias;
    jpushServiceFactory.resetBadge = _resetBadge;

    return jpushServiceFactory;
  });

在$ionicPlatform.ready中进行代码初始化

$ionicPlatform.ready(function () {
  if (window.cordova && window.cordova.plugins && window.cordova.plugins.Keyboard) {
    cordova.plugins.Keyboard.hideKeyboardAccessoryBar(false);
    cordova.plugins.Keyboard.disableScroll(true);
  }
  if (window.StatusBar) {
    StatusBar.styleDefault();
  }
  var setAliasCallback = function (event) {
    console.log('alias' + event.alias);
  };
  //android的成功回调,ios的查看发现并没有找到回调方法
  var openNotificationInAndroidCallback = function (data) {
    var json = data;
    if (typeof data === 'string') {
      json = JSON.parse(data);
    }
    $state.go('my-message');
  };
  var config = {
    stac: setAliasCallback,
    oniac: openNotificationInAndroidCallback,
    onios: receiveNotificationIniOSCallback
  };
  window.plugins.jPushPlugin.setAlias(StorageService.getStorage('userId').replace(reg, ''));
  window.plugins.jPushPlugin.setBadge(0);//设置角标数值
  jPushService.init(config);
});

说明:Android可以通过设置openNotificationInAndroidCallback(官方提供的方法)但是iOS并没有找到,所以通过jpush.openNotification这个事件实现的,它的意思就是点击通知进入应用程序时会触发该事件(写在service里面,Android和ios都可以使用)

相关文章

  • Cordova极光推送相关配置

    准备材料 首先去极光官网注册账号并创建应用 下载Cordova推送插件并按照说明进行添加插件配置 iOS推送证书(...

  • 将极光推送安装到cordova项目中

    安装cordova安装极光推送插件到cordova获取极光推送RegistrationID 第一步:在激光注册并创...

  • 极光推送配置

    1、安装cordova 因为极光推送使用的是cordova插件,所以我们要先安装cordova: 通过npm包管理...

  • 极光推送(二)——推送的使用

    前言 在极光推送(一)——配置中讲过了极光推送的配置,这节讲讲极光推送的使用参考文档极光官网 下面以我写的demo...

  • ionic2集成激光推送

    极光推送插件安装 安装插件ionic cordova plugin add jpush-phonegap-plug...

  • Ionic3 消息推送

    推荐采用极光JPush 推送。 1. ionic cordova add android platform 2. ...

  • ionic3 集成极光推送自定义消息爬坑备忘

    1.cordova的极光推送插件有三种下载方式 (1)通过 Cordova Plugins 安装,要求 Cordo...

  • 极光统计

    前言 极光统计可以独立使用,其配置和极光推送相似 极光统计配置 极光统计代码编写 极光统计方法调用 具体配置请参考...

  • iOS极光推送看我就行

    随着极光版本得不断更迭,许多人看着极光demo看的一脸懵逼,这里更新最新的极光推送Xcode配置和相关代码。 当我...

  • 极光推送进行远程推送

    借阅:极光推送进行远程推送 怎么使用极光推送进行远程推送 在极光官网注册极光推送创建一个应用在应用配置中导入两个证...

网友评论

    本文标题:Cordova极光推送相关配置

    本文链接:https://www.haomeiwen.com/subject/fqdrattx.html