首页 > 解决方案 > 创建 SBNotificationHub 实例时出错

问题描述

我正在尝试在 iOS 上的 Xamarin 应用程序中实现推送通知。使用文档中的示例,我有:

        if (_hub == null)
        {
            string connectionString = "Endpoint=<whatever>";
            string hubName = "<hub name>";
            _hub = new SBNotificationHub(connectionString, hubName);
        }

出于某种原因,我遇到了一个异常:“Foundation.MonoTouchException:引发了 Objective-C 异常。名称:NSInvalidArgumentException 原因:*** -[__NSDictionaryM setObject:forKey:]: key cannot be nil Native stack trace:”

任何想法或方向都值得赞赏。更多关于错误:

    1   libobjc.A.dylib                     0x00000001988ea9f8 objc_exception_throw + 56
2   CoreFoundation                      0x0000000199688f8c _CFArgv + 0
3   CoreFoundation                      0x00000001995fe2b4 <redacted> + 904
4   TennisUmpireXamariniOS              0x0000000102355038 -[SBLocalStorage readContent] + 508
5   TennisUmpireXamariniOS              0x000000010235472c -[SBLocalStorage initWithNotificationHubPath:] + 296
6   TennisUmpireXamariniOS              0x000000010234dbe4 -[SBNotificationHub initWithConnectionString:notificationHubPath:] + 420
7   TennisUmpireXamariniOS              0x0000000104530a7c wrapper_managed_to_native_ApiDefinition_Messaging_IntPtr_objc_msgSend_IntPtr_IntPtr_intptr_intptr_intptr_intptr + 236
8   TennisUmpireXamariniOS              0x0000000104521038 WindowsAzure_Messaging_SBNotificationHub__ctor_string_string + 792
9   TennisUmpireXamariniOS              0x0000000102418a00 TennisUmpireXamarin_iOS_AppDelegate_RegisteredForRemoteNotifications_UIKit_UIApplication_Foundation_NSData + 480
10  TennisUmpireXamariniOS              0x000000010271d998 wrapper_runtime_invoke_object_runtime_invoke_dynamic_intptr_intptr_intptr_intptr + 248
11  TennisUmpireXamariniOS              0x0000000104d30e80 mono_jit_runtime_invoke + 948
12  TennisUmpireXamariniOS              0x0000000104db54e8 mono_runtime_invoke_checked + 144
13  TennisUmpireXamariniOS              0x0000000104db8d90 mono_runtime_invoke + 80
14  TennisUmpireXamariniOS              0x00000001023ccf3c _ZL31native_to_managed_trampoline_23P11objc_objectP13objc_selectorPP11_MonoMethodP13UIApplicationP6NSDataj + 680
15  TennisUmpireXamariniOS              0x00000001023ccc88 -[AppDelegate application:didRegisterForRemoteNotificationsWithDeviceToken:] + 64
16  libdispatch.dylib                   0x000000019914fa38 <redacted> + 24
17  libdispatch.dylib                   0x00000001991507d4 <redacted> + 16
18  libdispatch.dylib                   0x00000001990fe004 <redacted> + 1068
19  CoreFoundation                      0x00000001996a0ec0 <redacted> + 12
20  CoreFoundation                      0x000000019969bdf8 <redacted> + 1924
21  CoreFoundation                      0x000000019969b354 CFRunLoopRunSpecific + 436
22  GraphicsServices                    0x000000019b89b79c GSEventRunModal + 104
23  UIKitCore                           0x00000001c5897b68 UIApplicationMain + 212
24  TennisUmpireXamariniOS              0x00000001031962c8 wrapper_managed_to_native_UIKit_UIApplication_UIApplicationMain_int_string___intptr_intptr + 328
25  TennisUmpireXamariniOS              0x00000001030f723c UIKit_UIApplication_Main_string___intptr_intptr + 44
26  TennisUmpireXamariniOS              0x00000001030f71fc UIKit_UIApplication_Main_string___string_string + 172
27  TennisUmpireXamariniOS              0x00000001024178c0 TennisUmpireXamarin_iOS_Application_Main_string__ + 128
28  TennisUmpireXamariniOS              0x000000010271d998 wrapper_runtime_invoke_object_runtime_invoke_dynamic_intptr_intptr_intptr_intptr + 248
29  TennisUmpireXamariniOS              0x0000000104d30e80 mono_jit_runtime_invoke + 948
30  TennisUmpireXamariniOS              0x0000000104db54e8 mono_runtime_invoke_checked + 144
31  TennisUmpireXamariniOS              0x0000000104dbb320 mono_runtime_exec_main_checked + 120
32  TennisUmpireXamariniOS              0x0000000104d1141c mono_jit_exec + 268
33  TennisUmpireXamariniOS              0x0000000104ea94d4 xamarin_main + 2184
34  TennisUmpireXamariniOS              0x00000001024177b8 main + 96
35  libdyld.dylib                       0x00000001991618e0 <redacted> + 4

标签: xamarin.formsxamarin.iosazure-notificationhub

解决方案


似乎没有人遇到这个问题,但我想我弄清楚了发生了什么并想把它写下来。

SBNotificationHub 组件将状态保存在存储中。调用构造函数时,会恢复此状态。我的构造函数参数很好,第一次调用没有任何错误。

但是,当我尝试调用 RegisterTemplate 方法时,我传递了无效参数,导致通知中心出现 400 错误。问题是即使使用这个无效参数,状态也会更新。

对 SBNotificationHub 构造函数的下一次调用试图恢复这种不一致的状态,并抛出了我在问题中发布的错误。

现在我会被卡住,直到应用程序被删除。这是版本https://www.nuget.org/packages/Xamarin.Azure.NotificationHubs.iOS/ (1.2.5.2)。问题是我使用了包https://www.nuget.org/packages/Xamarin.Azure.NotificationHubs.iOS-updated/,这是在 KeyChain 中存储状态的分叉版本。我们知道,即使卸载了应用程序,KeyChain 中的值仍然存在,所以即使我重新安装了我的应用程序,我也卡住了,直到我真正清除了设备。

因此,我切换到版本 1.2.5.2 至少能够在卸载应用程序后重新启动,然后解决我的 RegisterTemplate 调用有什么问题。

我认为,如果 RegisterTemplate 调用不成功,正确的行为是不更新状态。除此之外,如果存储状态(钥匙串与否)已损坏,则能够清除它会很好。或者,为什么构造函数甚至需要恢复状态?


推荐阅读