iOS的Xamarin Firebase给出FCM 501错误



我已经为此挣扎了几天,并且在该主题上找到了许多其他帖子,但似乎没有解决我遇到的问题。我觉得这可能很简单,因为我已经尝试了几次削减项目,并且始终会遇到相同的失败。我可以在Android中收到Firebase消息,但iOS始终击败我。

我正在使用带有iOS 10的手机作为测试。调试代码始终可以返回令牌,但是在连接时,错误'操作无法完成。(com.google.fcm错误501。)'已返回。我附上一些示例代码 - 这是挫败感

的事实。
    public partial class AppDelegate : global::Xamarin.Forms.Platform.iOS.FormsApplicationDelegate, IUNUserNotificationCenterDelegate, IMessagingDelegate
{
    //
    // This method is invoked when the application has loaded and is ready to run. In this 
    // method you should instantiate the window, load the UI into it and then make the window
    // visible.
    //
    // You have 17 seconds to return from this method, or iOS will terminate your application.
    //
    public override bool FinishedLaunching(UIApplication app, NSDictionary options)
    {
        global::Xamarin.Forms.Forms.Init ();
        LoadApplication (new FirebaseTest.App (""));
        RegisterForNotificationFCM();
        return base.FinishedLaunching (app, options);
    }
    void RegisterForNotificationFCM()
    {
        // Register your app for remote notifications.
        if (UIDevice.CurrentDevice.CheckSystemVersion(10, 0))
        {
            // iOS 10 or later
            var authOptions = UNAuthorizationOptions.Alert | UNAuthorizationOptions.Badge | UNAuthorizationOptions.Sound;
            UNUserNotificationCenter.Current.RequestAuthorization(authOptions, (granted, error) => {
                Console.WriteLine(granted);
            });
            // For iOS 10 display notification (sent via APNS)
            UNUserNotificationCenter.Current.Delegate = this;
            // For iOS 10 data message (sent via FCM)
            Messaging.SharedInstance.Delegate = this;
        }
        else
        {
            // iOS 9 or before
            var allNotificationTypes = UIUserNotificationType.Alert | UIUserNotificationType.Badge | UIUserNotificationType.Sound;
            var settings = UIUserNotificationSettings.GetSettingsForTypes(allNotificationTypes, null);
            UIApplication.SharedApplication.RegisterUserNotificationSettings(settings);
        }
        UIApplication.SharedApplication.RegisterForRemoteNotifications();
        Firebase.Analytics.Loader loader1 = new Firebase.Analytics.Loader();
        Firebase.InstanceID.Loader loader2 = new Firebase.InstanceID.Loader();
        //Firebase.Core.App.Configure();
        Firebase.InstanceID.InstanceId.Notifications.ObserveTokenRefresh((sender, e) =>
        {
            var newToken = Firebase.InstanceID.InstanceId.SharedInstance.Token;
            System.Diagnostics.Debug.WriteLine(newToken);
            connectFCM();
        });
    }
    public override void DidEnterBackground(UIApplication uiApplication)
    {
        Messaging.SharedInstance.ShouldEstablishDirectChannel = false;
    }
    public override void OnActivated(UIApplication uiApplication)
    {
        base.OnActivated(uiApplication);
    }
    public override void RegisteredForRemoteNotifications(UIApplication application, NSData deviceToken)
    {
        Messaging.SharedInstance.ApnsToken = deviceToken;
        connectFCM();
        //Firebase.InstanceID.InstanceId.SharedInstance.SetApnsToken(deviceToken, Firebase.InstanceID.ApnsTokenType.Prod);
    }
    public void DidRefreshRegistrationToken(Messaging msg, string str)
    {
    }
    //Fire when background received notification is clicked
    public override void DidReceiveRemoteNotification(UIApplication application, NSDictionary userInfo, Action<UIBackgroundFetchResult> completionHandler)
    {
        //Messaging.SharedInstance.AppDidReceiveMessage(userInfo);
        System.Diagnostics.Debug.WriteLine(userInfo);
        // Generate custom event
        NSString[] keys = { new NSString("Event_type") };
        NSObject[] values = { new NSString("Recieve_Notification") };
        var parameters = NSDictionary<NSString, NSObject>.FromObjectsAndKeys(keys, values, keys.Length);
        // Send custom event
        Firebase.Analytics.Analytics.LogEvent("CustomEvent", parameters);
        if (application.ApplicationState == UIApplicationState.Active)
        {
            System.Diagnostics.Debug.WriteLine(userInfo);
            var aps_d = userInfo["aps"] as NSDictionary;
            var alert_d = aps_d["alert"] as NSDictionary;
            var body = alert_d["body"] as NSString;
            var title = alert_d["title"] as NSString;
            //debugAlert(title, body);
        }
    }
    [Export("userNotificationCenter:willPresentNotification:withCompletionHandler:")]
    public void WillPresentNotification(UNUserNotificationCenter center, UNNotification notification, Action<UNNotificationPresentationOptions> completionHandler)
    {
        // Do your magic to handle the notification data
        System.Console.WriteLine(notification.Request.Content.UserInfo);
    }
    // Receive data message on iOS 10 devices.
    public void ApplicationReceivedRemoteMessage(RemoteMessage remoteMessage)
    {
        Console.WriteLine(remoteMessage.AppData);
    }
    private void connectFCM()
    {
        //Messaging.SharedInstance.ShouldEstablishDirectChannel = true;
        //Messaging.SharedInstance.Subscribe("/topics/topic");
        Messaging.SharedInstance.Connect((error) =>
        {
            if (error == null)
            {
                Messaging.SharedInstance.Subscribe("/topics/topic");
            }
            System.Diagnostics.Debug.WriteLine(error != null ? "error occured" : "connect success");
        });
    }

这些功能已从许多其他关于同一主题的帖子中删除,就像您变得越来越绝望时一样。我认为Firebase控制台已设置好。我在工作Android One的一边添加了iOS作为应用程序,并添加了Mac上创建的身份验证密钥。(令人惊讶的是,即使没有此iOS应用程序作为Firebase项目的一部分,我仍然可以将其恢复原状 - 不是我所期望的)已为此应用创建了证书,并且已重新创建了配置配置文件并删除了旧的配置文件。

我不确定还要添加什么 - 有人请让我摆脱痛苦...

最后到达那里。其他人要检查的东西 - 将app.configure()移至connectfcm

    private void connectFCM()
    {
        Firebase.Core.App.Configure();
        Messaging.SharedInstance.ShouldEstablishDirectChannel = true;
    }

并将以下内容添加到info.plist

<key>NSExceptionDomains</key>
<dict>
    <key>firebaseio.com</key>
    <dict>
        <key>NSThirdPartyExceptionRequiresForwardSecrecy</key>
        <true/>
        <key>NSIncludesSubdomains</key>
        <true/>
    </dict>
</dict>
<key>UIBackgroundModes</key>
<array>
    <string>remote-notification</string>
</array>

相关内容

  • 没有找到相关文章

最新更新