Go to file
2017-07-21 13:52:37 +08:00
doc Update setTagsWithAlias callback. 2017-07-07 11:23:56 +08:00
example Optimize API 2017-05-26 16:17:54 +08:00
hooks add: check does com.apple.Push attribute exist in .pbxproj to avoid not found error. 2017-06-29 15:15:12 +08:00
src Update ios sdk to 3.0.6 2017-07-21 13:52:37 +08:00
www Add getConnectionState API 2017-06-22 12:30:47 +08:00
.gitignore Update .gitignore 2017-05-16 22:15:59 +08:00
.travis.yml update doc 2016-04-21 14:51:22 +08:00
license Update README & license. 2016-08-01 00:08:51 +08:00
package.json Update version to 3.2.2 2017-07-12 10:16:10 +08:00
plugin.xml Update ios sdk to 3.0.6 2017-07-21 13:52:37 +08:00
README.md Update version to 3.2.2 2017-07-12 10:16:10 +08:00

JPush PhoneGap / Cordova Plugin

Build Status release platforms weibo

支持 iOS, Android 的 Cordova 推送插件。

如需要 IM 功能的插件,可关注 JMessage Cordova Plugin。 如需要短信验证码功能的插件,可关注 JSMS Cordova Plugin

Install

  • 通过 Cordova Plugins 安装,要求 Cordova CLI 5.0+

    cordova plugin add jpush-phonegap-plugin --variable APP_KEY=your_jpush_appkey
    
  • 或直接通过 url 安装:

    cordova plugin add https://github.com/jpush/jpush-phonegap-plugin.git --variable APP_KEY=your_jpush_appkey  
    
  • 或下载到本地安装:

    cordova plugin add Your_Plugin_Path  --variable APP_KEY=your_jpush_appkey
    

在使用 Xcode 8 调试 iOS 项目时,需要先在项目配置界面的 Capabilities 中打开 Push Notifications 开关。

Usage

API

Demo

插件项目中包含一个简单的 Demo。若想参考可以在 /example 文件夹内找到并拷贝以下文件:

example/index.html -> www/index.html
example/css/* -> www/css
example/js/* -> www/js

关于 PhoneGap build 云服务

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

FAQ

如果遇到了疑问,请优先参考 Demo 和 API 文档。若还无法解决,可到 Issues 提问。

Android

在 Eclipse 中 import 工程之后出现:Type CallbackContext cannot be resolved to a type

右键单击工程名 -> Build Path -> Config Build Path -> Projects -> 选中工程名称 -> CordovaLib -> 点击 add。

如何自定义通知声音?

Android 因为各 Rom 的高度定制化,不像 iOS 一样能有一个统一的管理,如果在 Android 中想自定义通知铃声,推荐通过 JPush 推送自定义 消息,之后在 jpush.receiveMessage 事件监听中通过 Cordova Local-Notification Plugin 触发通知,再配合 Cordova Background Plugin 插件保证应用的后台运行。

关闭 App 后收不到通知

Android 的推送通过长连接的方式实现,只有在连接保持的情况下才能收到通知。而有的第三方 ROM 会限制一般应用服务的自启动,也就是 在退出应用后,应用的所有服务均被杀死,且无法自启动,所以就会收不到通知。

目前 JPush 是做了应用互相拉起机制的,也就是当用户打开其他集成了 JPush 的应用时,你的应用也能同时收到推送消息。

如果你的应用希望随时都能收到推送,官方推荐是通过文案的方式引导用户在设置中允许你的应用能够自启动,常见机型的设置方法可以参考这里

或者自己实现应用保活,网上有很多相关文章(不推荐)。

为什么 QQ、微信之类的应用退出后还能够收到通知因为这些大厂应用手机厂商默认都会加入自启动白名单中也不会在应用退出后杀死它们的相关服务。 如果你多加留意,就会发现非大厂的应用如果你一段时间不用都是收不到推送的。

iOS

打包时遇到 i386 打包失败怎么办?

cordova platform update ios

ionic 2 如何调用 API

issue 179

PushConfig.plist 文件中的字段都是什么意思?

  • Appkey应用标识。
  • Channel渠道标识。
  • IsProduction是否生产环境。
  • IsIDFA是否使用 IDFA 启动 SDK。

刚集成完插件收不到推送怎么办?

请首先按照正确方式再次配置证书、描述文件,具体可参考 iOS 证书设置指南

iOS 集成插件白屏、或无法启动插件、或打包报错无法找到需要引入的文件怎么办?

按照以下步骤逐个尝试:

  • 升级至 Xcode 8
  • 先删除插件、再重装插件(先使用 cordova platform add ios,后使用 cordova plugin add

Support

Contribute

Please contribute! Look at the issues.

License

MIT © JiGuang