35

对于 Swift3 / iOS10,请参阅此链接:

ios10、Swift 3 和 Firebase 推送通知 (FCM)

我正在尝试将 Firebase 用于通知,并且完全按照文档中的描述进行了集成。但我不明白为什么它不起作用。当我构建我的项目时,我看到这一行:

2016-05-25 16:09:34.987: <FIRInstanceID/WARNING> Failed to fetch default token Error Domain=com.firebase.iid Code=0 "(null)"

这是我的 AppDelegate:

 func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
    FIRApp.configure()
    FIRDatabase.database().persistenceEnabled = true
     var service: DataService = DataService()
    service.start()
    registerForPushNotifications(application)
    application.registerForRemoteNotifications()
    return true
}

func registerForPushNotifications(application: UIApplication) {
    let notificationSettings = UIUserNotificationSettings(
        forTypes: [.Badge, .Sound, .Alert], categories: nil)
    application.registerUserNotificationSettings(notificationSettings)
}

func application(application: UIApplication, didRegisterUserNotificationSettings notificationSettings: UIUserNotificationSettings) {
    if notificationSettings.types != .None {
        application.registerForRemoteNotifications()
    }
}

func application(application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: NSData) {
    let tokenChars = UnsafePointer<CChar>(deviceToken.bytes)
    var tokenString = ""

    for i in 0..<deviceToken.length {
        tokenString += String(format: "%02.2hhx", arguments: [tokenChars[i]])
    }

    FIRInstanceID.instanceID().setAPNSToken(deviceToken, type: FIRInstanceIDAPNSTokenType.Unknown)
    print("Device Token:", tokenString)
}
func application(application: UIApplication, didReceiveRemoteNotification userInfo: [NSObject : AnyObject], fetchCompletionHandler completionHandler: (UIBackgroundFetchResult) -> Void)  {
    // Print message ID.
    print("Message ID: \(userInfo["gcm.message_id"]!)")

    // Print full message.
    print("%@", userInfo)
}
4

6 回答 6

22

我也有同样的问题,但对我没有任何帮助。但是你所要做的就是去你的firebase控制台,然后找到你的项目并进入它的设置,在那里检查它的云消息选项卡并将你的.p12证书上传到那里。

而已!快乐编码:)

于 2016-07-15T11:54:02.117 回答
13

1.在didFinishLaunchingWithOptions方法中设置Notification Observer

2.然后设置tokenRefreshNotification方法然后你在这个方法中得到Token。

请参阅下面的代码

import Firebase
import FirebaseMessaging

override func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
  FIRApp.configure()

      NotificationCenter.default.addObserver(self,
                                                     selector: #selector(self.tokenRefreshNotification(notification:)),
                                                     name: NSNotification.Name.firInstanceIDTokenRefresh,
                                                     object: nil)
}

// NOTE: Need to use this when swizzling is disabled
public func application(application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: NSData) {

  FIRInstanceID.instanceID().setAPNSToken(deviceToken, type: FIRInstanceIDAPNSTokenType.Sandbox)
}

func tokenRefreshNotification(notification: NSNotification) {
  // NOTE: It can be nil here
  let refreshedToken = FIRInstanceID.instanceID().token()
  print("InstanceID token: \(refreshedToken)")

  connectToFcm()
}

func connectToFcm() {
  FIRMessaging.messaging().connectWithCompletion { (error) in
    if (error != nil) {
      print("Unable to connect with FCM. \(error)")
    } else {
      print("Connected to FCM.")
    }
  }
}

public func application(application: UIApplication, didReceiveRemoteNotification userInfo: [NSObject : AnyObject]) {
  print(userInfo)
}
于 2016-07-13T12:15:46.360 回答
4

1 - 您是否按照谷歌文档中的说明正确配置了您的证书(我不记得这里的过程,它很长......)?(https://firebase.google.com/docs/cloud-messaging/ios/certs#configure_an_app_id_for_push_notifications

2 - 我在设置 FCM 时遇到了一些困难。一旦我认为一切正常但通知仍然无法正常工作,我决定从手机中完全删除该应用程序,清理我的构建文件夹并重新安装整个东西。在那之后,它正在工作。

3 - 应用程序正在接收通知,但我仍然收到“无法获取默认令牌...”消息。过了一会儿就消失了。不要问我为什么!

这不是一个真正正确的答案,我只是分享我的经验,因为我知道配置通知并不容易,并且欢迎每条线索。所以也许这个可以提供帮助。干杯:)

于 2016-07-03T10:56:07.927 回答
3

在尝试了以上所有方法(以及我在其他地方可以找到的任何东西)之后,解决问题的方法就是搬家

let token = FIRInstanceID.instanceID().token()

在按下按钮时调用,而不是在应用加载时调用。

我知道这可能不是最优雅的解决方案,但它足以用于调试目的。我猜服务器无法立即使用令牌,并且需要一些时间才能生成。

于 2016-11-20T20:37:26.937 回答
3

上面的答案涵盖了大部分问题,但我遇到了同样的问题,我发现以下信息很有用:

  1. Firebase 可以随时“轮换”(更改)用户的 FCM 令牌。这是您的服务器将用于向设备发送推送通知的 128 个字符的 ID。

  2. Firebase 文档说最佳实践是使用委托来监视委托回调方法的更改:

    - (void)messaging:(nonnull FIRMessaging *)messaging didRefreshRegistrationToken:(nonnull NSString *)fcmToken
    

[对象-C]

func messaging(_ messaging: Messaging, didRefreshRegistrationToken fcmToken: String)

[迅速]

每次更改都应调用委托方法,此时您可以更新服务器中的记录。

  1. 不幸的是,这对我不起作用,我有一个委托,但没有调用回调。因此,我不得不在每次应用启动时手动更新令牌(如上面的@micheal chein 所建议),如下所示:

    NSString *deviceToken = [FIRInstanceID instanceID].token; // Send this to your server
    

    [对象-C]

    let token = FIRInstanceID.instanceID().token() // Send this to your server
    

    [迅速]

** 重要提示:延迟(20-25 秒)后更新令牌,因为轮换有时只能在一段时间后反映。您可以为此使用计时器。

  1. 在此之后,我仍然收到 APNS 警告/错误消息:

    2017-06-06 09:21:49.520: <FIRInstanceID/WARNING> Failed to fetch APNS token Error Domain=com.firebase.iid Code=1001 "(null)"
    

但是,推送通知每次都有效。所以我认为日志消息有点不对劲(可能时间不正确)。如果您可以让选项 2 为您工作,那么一定要这样做!

于 2017-06-06T07:32:37.307 回答
2

FCM 为我工作,然后就停止了。我按照 Rabs G. 的建议做了,删除了该应用程序并重新安装,通知又开始工作了。

于 2016-11-06T14:53:14.223 回答