Go to file
2016-04-12 14:50:27 +08:00
document optimize code & update doc 2016-04-11 15:21:59 +08:00
example optimize code & update doc 2016-04-11 15:21:59 +08:00
scripts 抽离API_KEY的配置 2015-08-06 11:08:28 +08:00
src Merge branch 'master' into dev 2016-04-12 14:50:27 +08:00
www optimize code & update doc 2016-04-11 15:21:59 +08:00
.gitignore add gitignore file 2015-01-04 09:41:29 +08:00
package.json version 2.1.1 2016-04-08 09:43:00 +08:00
plugin.xml update android sdk to 2.1.3 2016-04-08 18:01:27 +08:00
README.md optimize code & update doc 2016-04-11 15:21:59 +08:00

JPush PhoneGap/Cordova Plugin

JPush-PhoneGap-Plugin 支持 iOS, Android 的推送插件。

功能特性: 支持 iOS, Android 的极光推送插件。

功能特性

  • 发送推送通知
  • 发送推送自定义消息
  • 设置推送标签和别名
  • 设置角标iOS

如需要 IM 功能插件,请关注 jmessage-phonegap-plugin

安装

###准备工作

  1. cordova create 文件夹名字 包名 应用名字

     cordova create Myproj com.myproj.jpush MyTestProj
    
  2. 添加平台

     cd Myproj
     cordova platform add android  
     cordova platform add ios
    
     ps:这里请注意iOS平台必须先执行 `cordova platform add ios`,
     然后再执行 `cordova plugin add xxxxx` 命令,不然有一些必须要的链接库需要手动添加
    

###Cordova CLI / PhoneGap 安装 Android & iOS

1). 安装 JPush PhoneGap Plugin, 有两种方法:

方法一:在线安装

通过 cordova plugins 安装,要求 phonegap/cordova CLI 5.0+ (current stable v2.1.1)

cordova plugin add jpush-phonegap-plugin --variable API_KEY=your_jpush_appkey

直接通过 url 安装unstable

cordova plugin add https://github.com/jpush/jpush-phonegap-plugin.git --variable API_KEY=your_jpush_appkey  

方法二:下载到本地再安装

使用 git 命令将 JPush PhoneGap 插件下载的本地,将这个目录标记为 $JPUSH_PLUGIN_DIR

git clone https://github.com/jpush/jpush-phonegap-plugin.git
cordova plugin add $JPUSH_PLUGIN_DIR  --variable API_KEY=your_jpush_appkey

2). 安装 org.apache.cordova.device

 cordova plugin add org.apache.cordova.device

3). 在 js 中调用函数,初始化 JPush SDK

//由于 PhoneGap 插件采用了 Lazy load 的特性,所以建议在 js 文件能执行的最开始就添加
window.plugins.jPushPlugin.init();

Android 手动安装

Android 手动安装文档地址

iOS 手动安装

IOS手动安装文档地址

###示例

"$JPUSH_PLUGIN_DIR/example"文件夹内找到并拷贝以下文件

	src/example/index.html to www/index.html
	src/example/css/* to www/css
	src/example/js/* to www/js

###关于'PhoneGap build'云服务

该项目基于 cordova 实现,目前无法使用 'PhoneGap build' 云服务进行打包,建议使用本地环境进行打包

API 说明

插件的 API 集中在 JPushPlugin.js 文件中,该文件的具体位置如下:

Android:

[Project]/assets/www/plugins/cn.jpush.phonegap.JPushPlugin/www

iOS:

[Project]/www/plugins/cn.jpush.phonegap.JPushPlugin/www

具体的 API 请参考下面:

iOS 和 Android 通用 API 简介

  • 停止与恢复推送服务

      window.plugins.jPushPlugin.init()
      window.plugins.jPushPlugin.stopPush()
      window.plugins.jPushPlugin.resumePush()
      window.plugins.jPushPlugin.isPushStopped(callback)
    
  • 获取 RegistrationID

      window.plugins.jPushPlugin.getRegistrationID(callback)
    
  • 别名与标签

      window.plugins.jPushPlugin.setTagsWithAlias(tags, alias)
      window.plugins.jPushPlugin.setTags(tags)
      window.plugins.jPushPlugin.setAlias(alias)
    
      event - jpush.setTagsWithAlias //三个方法都是触发该回调事件
    
  • 获取点击通知内容

      event - jpush.openNotification
    
  • 获取通知内容

      event - jpush.receiveNotification
    
  • 获取自定义消息推送内容

      event - jpush.receiveMessage
    

    通用 API 详细说明

iOS API简介

  • 获取自定义消息推送内容

      //推荐使用事件的方式传递,但同时保留了 receiveMessageIniOSCallback 的回调函数,兼容以前的代码
      window.plugins.jPushPlugin.receiveMessageIniOSCallback(data)
    
      event - jpush.receiveMessage
    
  • 页面的统计

      window.plugins.jPushPlugin.startLogPageView(pageName)
      window.plugins.jPushPlugin.stopLogPageView(pageName)
      window.plugins.jPushPlugin.beginLogPageView(pageName, duration)
    
  • 设置 Badge

      window.plugins.jPushPlugin.setBadge(value)
      window.plugins.jPushPlugin.resetBadge()
      window.plugins.jPushPlugin.setApplicationIconBadgeNumber(badge)
      window.plugins.JPushPlugin.getApplicationIconBadgeNumber(callback)
    
  • 本地通知

      window.plugins.JPushPlugin.addLocalNotificationForIOS(delayTime, content,
      	badge, notificationID, extras)
      window.plugins.JPushPlugin.deleteLocalNotificationWithIdentifierKeyInIOS()
      window.plugins.JPushPlugin.clearAllLocalNotifications()
    
  • 日志等级设置

      window.plugins.jPushPlugin.setDebugModeFromIos()
      window.plugins.jPushPlugin.setLogOFF()
      window.plugins.JPushPlugin.setCrashLogON()
    
  • 地理位置上报

      window.plugins.JPushPlugin.setLocation(latitude, longitude)
    

    iOS API 详细说明

Android API简介

  • 获取集成日志

      window.plugins.jPushPlugin.setDebugMode(mode)
    
  • 接收推送消息和点击通知

      //下面这两个 API 是兼容旧有的代码
      window.plugins.jPushPlugin.receiveMessageInAndroidCallback(data)
      window.plugins.jPushPlugin.openNotificationInAndroidCallback(data)
    
  • 统计分析

      window.plugins.jPushPlugin.setStatisticsOpen(boolean)
    

    或在 MainActivity 中的 onPause() 和 onResume() 方法中分别调用 JPushInterface.onPause(this) 和 JPushInterface.onResume(this) 来启用统计分析功能, 如果使用这种方式启用统计分析功能,则 window.plugins.jPushPlugin.setStatisticsOpen(boolean) 方法不再有效,建议不要同时使用。

  • 清除通知

      window.plugins.jPushPlugin.clearAllNotification()
    
  • 通知栏样式定制

      window.plugins.jPushPlugin.setBasicPushNotificationBuilder = function()
      window.plugins.jPushPlugin.setCustomPushNotificationBuilder = function()
    
  • 设置保留最近通知条数

      window.plugins.jPushPlugin.setLatestNotificationNum(num)
    
  • 本地通知

      window.plugins.jPushPlugin.addLocalNotification(builderId, content,
      		title, notificaitonID, broadcastTime, extras)
      window.plugins.jPushPlugin.removeLocalNotification(notificationID)
      window.plugins.jPushPlugin.clearLocalNotifications()
    

    Android API 详细说明

###常见问题

####1. Android

eclipse 中 PhoneGap 工程 import 之后出现:`Type CallbackContext cannot be resolved to a type`
解决方案eclipse 中右键单击工程名Build Path -> Config Build Path -> Projects -> 选中工程名称 -> CordovaLib -> 点击 add

####2. iOS 设置 / 修改 APP_KEY

在 PushConfig.plist 中修改。
PushConfig.plist 其他值说明:
	CHANNEL: 渠道标识
	IsProduction: 是否生产环境(暂未启用)

###更多 JPush 官网文档