创建SBNotificationHub实例时出错

时间:2019-05-27 17:13:48

标签: xamarin.forms xamarin.ios azure-notificationhub

我正在尝试在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:]:键不能为native本机堆栈跟踪:”

任何想法或寻找方向的方向都值得赞赏。有关错误的更多信息:

    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

1 个答案:

答案 0 :(得分:0)

似乎没有人遇到这个问题,但是我想我知道发生了什么,并希望将其写成文字。

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调用失败,则不更新状态。除此之外,如果状态已损坏,能够清除存储中的状态(是否为钥匙串),将是一个很好的选择。还是为什么构造函数甚至需要还原状态?