- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
即使在 FCM 示例项目中,当设备处于后台时,我也无法接收推送通知。当应用程序转到后台时,我收到此消息
与 FCM 断开连接
推送通知适用于除后台以外的所有其他场景。当应用程序出现在前台时,我也能收到通知。有人遇到过这种情况吗?欢迎任何想法。
我项目的appdelegate
#import "AppDelegate.h"
#if defined(__IPHONE_10_0) && __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_10_0
@import UserNotifications;
#endif
@import Firebase;
@import FirebaseInstanceID;
@import FirebaseMessaging;
// Implement UNUserNotificationCentbberDelegate to receive display notification via APNS for devices
// running iOS 10 and above. Implement FIRMessagingDelegate to receive data message via FCM for
// devices running iOS 10 and above.
#if defined(__IPHONE_10_0) && __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_10_0
@interface AppDelegate ()<UNUserNotificationCenterDelegate, FIRMessagingDelegate>
@end
#endif
// Copied from Apple's header in case it is missing in some cases (e.g. pre-Xcode 8 builds).
#ifndef NSFoundationVersionNumber_iOS_9_x_Max
#define NSFoundationVersionNumber_iOS_9_x_Max 1299
#endif
@implementation AppDelegate
@synthesize onlineChatConversation;
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
// Override point for customization after application launch.
// [FIRApp configure];
return YES;
}
+ (AppDelegate *)appDelegate
{
return (AppDelegate *)[[UIApplication sharedApplication] delegate];
}
-(void)enableNotification
{
UIApplication * appinstance =[UIApplication sharedApplication];
static dispatch_once_t onceToken;
dispatch_once (&onceToken, ^{
// Do some work that happens once
// Register for remote notifications
[self EnablePushNotification:appinstance];
});
}
//-(void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken{
//
//
// [[FIRInstanceID instanceID] setAPNSToken:deviceToken type:FIRInstanceIDAPNSTokenTypeSandbox];
//
// // [[FIRInstanceID instanceID] setAPNSToken:deviceToken type:FIRInstanceIDAPNSTokenTypeProd];
//
//}
/*
* Code for registering push notification
*/
- (void)EnablePushNotification:(UIApplication * )appinstance{
// Register for remote notifications
if (floor(NSFoundationVersionNumber) <= NSFoundationVersionNumber_iOS_7_1) {
// iOS 7.1 or earlier. Disable the deprecation warnings.
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Wdeprecated-declarations"
UIRemoteNotificationType allNotificationTypes =
(UIRemoteNotificationTypeSound |
UIRemoteNotificationTypeAlert |
UIRemoteNotificationTypeBadge);
[appinstance registerForRemoteNotificationTypes:allNotificationTypes];
#pragma clang diagnostic pop
} else {
// iOS 8 or later
// [START register_for_notifications]
if (floor(NSFoundationVersionNumber) <= NSFoundationVersionNumber_iOS_9_x_Max) {
UIUserNotificationType allNotificationTypes =
(UIUserNotificationTypeSound | UIUserNotificationTypeAlert | UIUserNotificationTypeBadge);
UIUserNotificationSettings *settings =
[UIUserNotificationSettings settingsForTypes:allNotificationTypes categories:nil];
[appinstance registerUserNotificationSettings:settings];
} else {
// iOS 10 or later
#if defined(__IPHONE_10_0) && __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_10_0
UNAuthorizationOptions authOptions =
UNAuthorizationOptionAlert
| UNAuthorizationOptionSound
| UNAuthorizationOptionBadge;
[[UNUserNotificationCenter currentNotificationCenter]
requestAuthorizationWithOptions:authOptions
completionHandler:^(BOOL granted, NSError * _Nullable error) {
}
];
// For iOS 10 display notification (sent via APNS)
[[UNUserNotificationCenter currentNotificationCenter] setDelegate:self];
// For iOS 10 data message (sent via FCM)
[[FIRMessaging messaging] setRemoteMessageDelegate:self];
#endif
}
[appinstance registerForRemoteNotifications];
// [END register_for_notifications]
}
// [START configure_firebase]
[FIRApp configure];
// [END configure_firebase]
// Add observer for InstanceID token refresh callback.
NSString *refreshedToken = [[FIRInstanceID instanceID] token];
NSLog(@" refreshedToken =%@",refreshedToken);
if (refreshedToken) {
[self registerUSerDevice:refreshedToken];
}
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(tokenRefreshNotification:)
name:kFIRInstanceIDTokenRefreshNotification object:nil];
}
// [START receive_message]
// To receive notifications for iOS 9 and below.
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo
fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler {
// If you are receiving a notification message while your app is in the background,
// this callback will not be fired till the user taps on the notification launching the application.
// TODO: Handle data of notification
// Print message ID.
// Print full message.
NSLog(@"%@", userInfo);
NSString * NotifMessage = [[userInfo objectForKey:@"notification"]objectForKey:@"body"];
NSString * Notiftype = [userInfo objectForKey:@"type"];
// NSString * Notiftitle = [[[userInfo objectForKey:@"notification"] objectForKey:@"notification"] objectForKey:@"title"];
// NSString * Notifbadge = [[[userInfo objectForKey:@"notification"] objectForKey:@"notification"] objectForKey:@"badge"];
// NSString * NotifSound = [[[userInfo objectForKey:@"notification"] objectForKey:@"notification"] objectForKey:@"sound"];
NSString *chatProviderId = [[NSUserDefaults standardUserDefaults] stringForKey:@"chatProviderId"];
if (([Notiftype isEqual:@"message"])) {
if ([NotifMessage isEqualToString:@"Your mobile device added successfully to receive notifications."]){
}else if([[userInfo objectForKey:@"sender_id"] isEqualToString:chatProviderId ]){
}
else{
[AGPushNoteView showWithNotificationMessage:[NSString stringWithFormat:@"%@",NotifMessage]];
[AGPushNoteView setMessageAction:^(NSString *NotifMessage){
NSLog(@"%@",NotifMessage);
if ([NotifMessage rangeOfString:@"You have new message from"].location != NSNotFound) {
[[NSNotificationCenter defaultCenter]
postNotificationName:@"openchatpage_Notification"
object:userInfo];
}else if ([NotifMessage rangeOfString:@"has requested for new appointment"].location != NSNotFound)
{
//NSLog(@"video consultation started %@",[userInfo objectForKey:@"key"]);
}else
{
}
// UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"PUSH"
// message:message
// delegate:nil
// cancelButtonTitle:@"Close"
// otherButtonTitles:nil];
// [alert show];
// UIStoryboard *mainStrotyBoard = [UIStoryboard storyboardWithName:@"Main" bundle:[NSBundle mainBundle]];
// ViewCardDetails *viewCardDetails = [mainStrotyBoard instantiateViewControllerWithIdentifier:@"viewcarddetails"];
// [self.navigationController pushViewController:viewCardDetails animated:YES];
// // [self.navigationController pushViewController:forgotPasswordViewController animated:YES];
// [self presentViewController:forgotPasswordViewController animated:YES completion:nil];
}];
}
}
if (([Notiftype isEqual:@"New Appointment"]||[Notiftype isEqual:@"Quick Appointment"])) {
[AGPushNoteView showWithNotificationMessage:[NSString stringWithFormat:@"%@",NotifMessage]];
[AGPushNoteView setMessageAction:^(NSString *NotifMessage) {
// [[NSNotificationCenter defaultCenter]
// postNotificationName:@"openApptlist_Notification"
// object:userInfo];
[[NSNotificationCenter defaultCenter]
postNotificationName:@"videoconsultationStart_Notif"
object:userInfo];
}];
UIViewController * lastvc = [[UIViewController alloc]init];
lastvc = [[[UIApplication sharedApplication] keyWindow] visibleViewController];
}
// [START ios_10_message_handling]
// Receive displayed notifications for iOS 10 devices.
#if defined(__IPHONE_10_0) && __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_10_0
- (void)userNotificationCenter:(UNUserNotificationCenter *)center
willPresentNotification:(UNNotification *)notification
withCompletionHandler:(void (^)(UNNotificationPresentationOptions))completionHandler {
// Print message ID.
NSDictionary *userInfo = notification.request.content.userInfo;
NSLog(@"Message ID: %@", userInfo[@"gcm.message_id"]);
// Print full message.
NSLog(@"%@", userInfo);
}
// Receive data message on iOS 10 devices.
- (void)applicationReceivedRemoteMessage:(FIRMessagingRemoteMessage *)remoteMessage {
// Print full message
NSLog(@"%@", [remoteMessage appData]);
}
#endif
// [END ios_10_message_handling]
// [START refresh_token]
- (void)tokenRefreshNotification:(NSNotification *)notification {
// Note that this callback will be fired everytime a new token is generated, including the first
// time. So if you need to retrieve the token as soon as it is available this is where that
// should be done.
NSString *refreshedToken = [[FIRInstanceID instanceID] token];
NSLog(@"InstanceID token: %@", refreshedToken);
if (refreshedToken) {
[self registerUSerDevice:refreshedToken];
}
// Connect to FCM since connection may have failed when attempted before having a token.
[self connectToFcm];
// TODO: If necessary send token to application server.
}
// [END refresh_token]
// [START connect_to_fcm]
- (void)connectToFcm {
[[FIRMessaging messaging] connectWithCompletion:^(NSError * _Nullable error) {
if (error != nil) {
NSLog(@"Unable to connect to FCM. %@", error);
} else {
NSLog(@"Connected to FCM.");
}
}];
}
// [END connect_to_fcm]
- (void)applicationDidBecomeActive:(UIApplication *)application {
[self connectToFcm];
}
// [START disconnect_from_fcm]
- (void)applicationDidEnterBackground:(UIApplication *)application {
[[FIRMessaging messaging] disconnect];
NSLog(@"Disconnected from FCM");
}
// [END disconnect_from_fcm]
- (void)applicationWillResignActive:(UIApplication *)application {
// Sent when the application is about to move from active to inactive state. This can occur for certain types of temporary interruptions (such as an incoming phone call or SMS message) or when the user quits the application and it begins the transition to the background state.
// Use this method to pause ongoing tasks, disable timers, and throttle down OpenGL ES frame rates. Games should use this method to pause the game.
}
- (void)applicationWillEnterForeground:(UIApplication *)application {
// Called as part of the transition from the background to the inactive state; here you can undo many of the changes made on entering the background.
}
- (void)applicationWillTerminate:(UIApplication *)application {
// Called when the application is about to terminate. Save data if appropriate. See also applicationDidEnterBackground:.
}
-(void) registerUSerDevice:(NSString *)token{
// UIAlertView *alertNotification = [[UIAlertView alloc] initWithTitle:@"2" message:@"register user device called" delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil];
//[alertNotification show];
NSLog(@"token %@",token);
//Sending token to server
NSString * baseurl = [CustomUtility getWebserviceforKey:@"serverAddress"];
NSString * apikey = [CustomUtility getWebserviceforKey:@"APIKEY"];
NSString *urlString = [NSString stringWithFormat:@"%@api/mobile_profiles/add_mobile_devise",baseurl];
NSString *user_token = [[NSUserDefaults standardUserDefaults] stringForKey:@"USER_TOKEN"];
// NSDictionary * jsonString = @{ @"user":@{@"user_token":user_token},@"api_key":@"C0VS9qojCDWTVOut251u4Y7f0H8eN8aF",@"token_id":@"token.tokenId"};
NSDictionary * jsonString = @{@"user":@{@"user_token":user_token,@"devise_id":token},@"api_key":apikey};
NSLog(@"jsonstring - %@",jsonString);
NSDictionary *headers = @{ @"content-type": @"application/json" };
NSData *postData = [NSJSONSerialization dataWithJSONObject:jsonString options:0 error:nil];
NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:[NSURL URLWithString:urlString] cachePolicy:NSURLRequestUseProtocolCachePolicy timeoutInterval:20.0];
[request setHTTPMethod:@"POST"];
[request setAllHTTPHeaderFields:headers];
[request setHTTPBody:postData];
[NSURLConnection sendAsynchronousRequest:request queue:[NSOperationQueue mainQueue] completionHandler:^(NSURLResponse *response,NSData *data, NSError *connectionError){
// UIAlertView *alertNotification = [[UIAlertView alloc] initWithTitle:@"3" message:@"Some response came" delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil];
// [alertNotification show];
NSHTTPURLResponse* httpResponse = (NSHTTPURLResponse*)response;
int code = (int)[httpResponse statusCode];
UIAlertView *alertNotification1 = [[UIAlertView alloc] initWithTitle:[NSString stringWithFormat:@"%d",code] message:@"Response" delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil];
// [alertNotification1 show];
if (connectionError == nil && data.length > 0) {
if (code == 200) {
if (data.length > 0){
// self.saveButton.enabled = YES;
// [self.activityindicator stopAnimating];
// self.activityindicator.hidden = YES;
NSDictionary *follow_favorite1 = [NSJSONSerialization JSONObjectWithData:data options:0 error:NULL];
NSLog(@"the responseString was %@", follow_favorite1);
if ([[follow_favorite1 objectForKey:@"success"]boolValue] == YES) {
// [self.navigationController popViewControllerAnimated:YES];
// UIAlertView *alertUser = [[UIAlertView alloc] initWithTitle:@"Success" message:[follow_favorite1 valueForKey:@"message"] delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil];
// [alertUser show];
}else {
UIAlertView *alertUser = [[UIAlertView alloc] initWithTitle:@"Error" message:[follow_favorite1 valueForKey:@"message"] delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil];
[alertUser show];
}
}else{
UIAlertView *errorsecurityquestion = [[UIAlertView alloc] initWithTitle:@"Error" message:@"Something went wrong" delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil];
[errorsecurityquestion show];
// self.saveButton.enabled = YES;
// [self.activityindicator stopAnimating ];
// self.activityindicator.hidden = YES;
}
}else{
}
}else
{
UIAlertView *connectionerroralert = [[UIAlertView alloc] initWithTitle:@"Error" message:@"Connection error please try again" delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil];
[connectionerroralert show];
// self.saveButton.enabled = YES;
// [self.activityindicator stopAnimating ];
// self.activityindicator.hidden = YES;
}
// NSDictionary *follow_favorite1 = [NSJSONSerialization JSONObjectWithData:data options:0 error:NULL];
// NSLog(@"the error is %@",follow_favorite1);
}];
}
@end
最佳答案
尝试在您的 info.plist 中将 FirebaseAppDelegateProxyEnabled
类型的“Boolean”值设为“NO”,然后检查您是否仍未收到任何通知。此问题的另一种可能解决方案是将消息的优先级设置为“高”,以便在应用程序处于后台时显示通知。
有关更多信息,请检查这些相关的 SO 问题:
关于ios - FCM 示例项目在后台未收到通知,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40611331/
从 0 开始搭建一套后台管理系统,成本巨大,所以都会选择一套成熟的组件库,基于此,再堆叠业务逻辑。我们公司的组件库基于 Ant Design。Ant Design 包含一套完整的后台解决方案,不仅
在我的 IOS 应用程序中,我有一个标记为 retain 的 NSDate* 属性 当我的应用程序再次激活时,属性值已被释放。 我是否误解了属性和内存管理的工作原理,我该如何防范? 最佳答案 很明显,
我有一个使用 BackgroundWorker 组件的示例 WinForms 应用程序。它工作正常,但是当我点击 Cancel 按钮取消后台线程时,它并没有取消线程。当我点击 Cancel 按钮调用
我目前正在开发一个应用程序,该应用程序在启动时会对服务器执行 ping 操作,该服务器会为每个连接的设备返回一个唯一标识符。设备每 5 秒从服务器检索另一页以获取一组不同的数据。这个唯一的 ID 可以
我正在开发一个应用程序,当它通过主页按钮在后台按下时,计时器应该启动,当应用程序返回前台并且计时器已经过了一定时间时,应该是执行。 我的问题是 当我的应用程序转到背景/前景? 是否有特殊的方法或其他技
我有 map View ,其中几乎没有 MKPointAnnotation。 一切正常,但是, View 的 MKPoiintAnnotation 的“背景”是“不可见的”,因此不是很“可见”。 我想
我在 iOS 中开发广告数据应用程序。我的应用程序广告数据在前台很好。但我想在 ios 后台宣传信标数据。我设置了背景外设设置。和广告数据 advertisingData = [CBAdvertise
如果我有一组操作,我想根据特定条件在后台工作程序中运行,例如,我有 10 个条件 if(a) BackgroundWorker doA = new backgroundworker() if(
我想独立运行一个函数。从我调用的函数中,我想在不等待其他函数结束的情况下返回。 我试过用 threadind,但这会等待,结束。 thread = threading.Thread(target=my
我想在用户在线时立即执行一些任务,即使他在后台也是如此。我正在使用 Reachability 类来检查互联网。但是当我在后台时,这个类没有通知我。我知道有人早些时候问过这个问题,但没有找到任何解决方案
我在后台播放文本转语音时出现间歇性(哎呀!)问题,由 Apple Watch 触发。我已经正确设置了后台模式、AVSession 类别和 WatchKitExtensionRequest 处理程序。
我有一个相当复杂的程序,所以我不会在这里转储整个程序。这是一个简化版本: class Report { private BackgroundWorker worker; public
我有一个任务在 backgroundworker 中运行。单击开始按钮,用户将启动该过程,并获得一个取消按钮来取消处理。 当用户点击取消时,我想显示一个消息框“进程尚未完成,你想继续吗”。 这里我希望
我有一个按以下方式编码的脚本。我想将它作为后台/守护进程运行,但是一旦我启动脚本,如果我关闭它从程序运行的终端窗口终止。我需要做什么来保持程序运行 loop do pid = fork do
我正在制作一个使用 ActivityRecognition API 在后台跟踪用户 Activity 的应用,如果用户在指定时间段(例如 1 小时)内停留在同一个地方,系统就会推送通知告诉用户去散步.
当尝试使用 URLSession 的 dataTaskPublisher 方法发送后台请求时: URLSession(configuration: URLSessionConfiguration.ba
当我编译这段代码时,我得到了他的错误,对象引用设置为null,错误位置在Dowork中,argumenttest.valueone = 8; public partial class Form1 :
有什么方法可以使用最小化或不活动的应用程序吗?我可以打开我的应用程序,然后打开并使用另一个应用程序,然后按一个按钮来激活我的程序吗? 例如,打开我的应用程序,打开 Safari,按下按钮(F1 或任何
我的具体要求是一个在后台运行的应用程序,被通知显示器即将进入休眠状态或者设备已经或即将达到空闲超时 - 然后唤醒并执行一些(简短的)一段代码。 我在这里找到了有关应用程序被置于后台或暂停的通知的引用:
我有一个 LSUIElement 设置为 1 的应用程序。它有一个内置编辑器,因此我希望该应用程序在编辑器打开时出现在 Cmd+Tab 循环中。 -(void)stepIntoForegrou
我是一名优秀的程序员,十分优秀!