给 iOS 应用添加推送功能是一件比较麻烦的事情,本篇文章收集了集成 jpush-react-native 的常见问题,目的是为了帮助用户更好的排查问题
1. 收不到推送
- 确保是在真机上测试,而不是在模拟器
- 自己的应用已经在 Apple developer 给应用配置推送功能,创建推送证书 (并且保证 bundle id 与 Apple developer 上的是一致的)如果之前没有接触过推送证书建议看视频来 👉 官方集成视频
- 能够获取 deviceToken 但是收不到推送, 如果是使用 xcode 8,检查 (Project -> Target -> Capabilities ) Push Notification 选项是否已经点开,如果没有需要点开
2. 收到一条通知 JS 层会有多个 ReceiveNotification 事件
- 升级 jpush-react-native 到最新版本
- 有没有在合适的地方 remove ReceiveNotification 事件,如果多次监听该事件会导致重复接收
3. 如何消除 应用 icon 的角标(badge)
调用 JPushModule.setBadge 方法 如果设为 0,则表示情况角标
JPushModule.setBadge(5, (badgeNumber) => {
console.log(badgeNumber)
});
4. 开发环境能够收到推送,生产环境收不到推送
-
如果是通过控制台发送的推送,检查环境选择是否正确
- 如果是调用 REST api 发送通知,请检查推送参数
- 手机应用是否是仍然是 开发环境, 如果不是请打包 Ad Hoc 来测试
5. 自定义消息事件无法触发
-
如果通过控制台发送的自定义消息,确保选择的是自定义消息,而不是通知
- 检查是否监听了 networkDidReceiveMessage 事件
6. 点击推送唤起应用的时候 OpenNotificationLaunchApp 不调用
- 升级 jpush-react-native 到最新版本(旧版本还没做缓存处理,新版本已修复)
- 检查监听 OpenNotification 的操作是否异步调用,有用户应为在异步回调中才执行监听操作,导致事件已经上抛到 js 层但 js 层还没执行监听操作的问题
- 如果如果不是使用原生路由也可能出现这个问题,把监听代码尽量放到应用启动的时候(可以把监听代码移动到 index 入口中)
7. 通知在前台展示问题
- iOS 10 开始允许通知在前台展示这个地方在 Native 代码中控制
// iOS 10 Support
- (void)jpushNotificationCenter:(UNUserNotificationCenter *)center willPresentNotification:(UNNotification *)notification withCompletionHandler:(void (^)(NSInteger))completionHandler {
// Required
NSDictionary * userInfo = notification.request.content.userInfo;
if([notification.request.trigger isKindOfClass:[UNPushNotificationTrigger class]]) {
[JPUSHService handleRemoteNotification:userInfo];
[[NSNotificationCenter defaultCenter] postNotificationName:kJPFDidReceiveRemoteNotification object:userInfo];
}
completionHandler(UNNotificationPresentationOptionAlert); // 需要执行这个方法,选择是否提醒用户,有Badge、Sound、Alert三种类型可以选择设置
}
- iOS 10 之前是系统控制,应用在前台推送不展示
8. 找不到头文件 RCTJPushModule.h
- 在 iOS 工程中如果找不到头文件可能要在 TARGETS-> BUILD SETTINGS -> Search Paths -> Header Search Paths 添加如下如路径
$(SRCROOT)/../node_modules/jpush-react-native/ios/RCTJPushModule/RCTJPushModule
RN 在 0.40.0 之后 不会自动加入这个路径了,要手动加一下
9. 在 iphone 5 的模拟器编译不通过
JPush SDK 在 3.0.0 及以后版本不再支持 i386 的模拟器了需要在 iphone 5s 以上版本中测试
10. 找不到 jcore-react-native
- 在 jpush-react-native 1.4.4 以后版本 需要通知安装 jcore-react-native 才能正常使用