準備材料
- 首先去極光官網注冊賬號并創建應用
- 下載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都可以使用)