当我进入主屏幕时,使用FacebookloginSDK崩溃

我最初下载了FBSDK的4.10版本,并将它们放到我的应用程序中,放在框架文件夹中。 意识到这些将不会随着时间的推移而得到更新,我将它们彻底删除,并尝试将它们作为豆荚添加到我的项目中。 成功安装了pod,我已经正确地将它们导入了桥接头文件,并且没有其他问题。 豆荚更新安装版本4.11导致我头痛。

我正在使用FBSDKLoginKit将用户login到他们的帐户并从中检索信息。 我能够找回用户信息的字典就好了。 然后我把这个信息传递给下一个ViewController。 在此之后的任何时候,如果我按下我的iPhone或模拟器上的主页button,应用程序将崩溃。 我得到的错误是

*** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '*** -[__NSPlaceholderDictionary initWithObjects:forKeys:count:]: attempt to insert nil object from objects[3]' 

如果我让用户通过Facebooklogin,继续到新的视图控制器,展开到先前的视图控制器,然后再次尝试login,也会发生此exception。 一旦在第二个屏幕上检索到他们的相关信息,我试图login用户,但是错误仍然存​​在。

我看到一个类似的问题,问“解决scheme”在哪里,FBSDKLoginKit将检索到的字典写入一个variables,如果检索到的字典有nil值,则抛出这个错误。

有什么事情可以在事情发生之前做到吗? 有没有人find解决办法?

这是我按下home时从模拟器的输出:

 *** First throw call stack: ( 0 CoreFoundation 0x0000000106f03d85 __exceptionPreprocess + 165 1 libobjc.A.dylib 0x000000010643edeb objc_exception_throw + 48 2 CoreFoundation 0x0000000106e0023e -[__NSPlaceholderDictionary initWithObjects:forKeys:count:] + 318 3 CoreFoundation 0x0000000106e125bb +[NSDictionary dictionaryWithObjects:forKeys:count:] + 59 4 APPNAME 0x0000000101607a1e -[FBSDKTimeSpentData instanceSuspend] + 622 5 APPNAME 0x000000010160766b +[FBSDKTimeSpentData suspend] + 59 6 APPNAME 0x00000001015b5986 -[FBSDKAppEvents applicationMovingFromActiveStateOrTerminating] + 262 7 CoreFoundation 0x0000000106ecdc8c __CFNOTIFICATIONCENTER_IS_CALLING_OUT_TO_AN_OBSERVER__ + 12 8 CoreFoundation 0x0000000106ecd9cb _CFXRegistrationPost + 427 9 CoreFoundation 0x0000000106ecd732 ___CFXNotificationPost_block_invoke + 50 10 CoreFoundation 0x0000000106f161e2 -[_CFXNotificationRegistrar find:object:observer:enumerator:] + 1986 11 CoreFoundation 0x0000000106dc5679 _CFXNotificationPost + 633 12 Foundation 0x000000010372ccd9 -[NSNotificationCenter postNotificationName:object:userInfo:] + 66 13 UIKit 0x0000000104a685ad -[UIApplication _deactivateForReason:notify:] + 629 14 UIKit 0x0000000104a6f1f1 __61-[UIApplication _sceneSettingsPreLifecycleEventDiffInspector]_block_invoke + 104 15 FrontBoardServices 0x0000000108f88d6c __52-[FBSSettingsDiffInspector inspectDiff:withContext:]_block_invoke27 + 213 16 Foundation 0x000000010377d5bb __NSIndexSetEnumerate + 1016 17 BaseBoard 0x000000010901ba8c -[BSSettingsDiff inspectChangesWithBlock:] + 116 18 FrontBoardServices 0x0000000108f83e4a -[FBSSettingsDiff inspectOtherChangesWithBlock:] + 92 19 FrontBoardServices 0x0000000108f88b2f -[FBSSettingsDiffInspector inspectDiff:withContext:] + 317 20 UIKit 0x0000000104a70880 __70-[UIApplication scene:didUpdateWithDiff:transitionContext:completion:]_block_invoke + 127 21 UIKit 0x0000000104a7052d -[UIApplication scene:didUpdateWithDiff:transitionContext:completion:] + 843 22 FrontBoardServices 0x0000000108f978c8 __FBSSERIALQUEUE_IS_CALLING_OUT_TO_A_BLOCK__ + 24 23 FrontBoardServices 0x0000000108f97741 -[FBSSerialQueue _performNext] + 178 24 FrontBoardServices 0x0000000108f97aca -[FBSSerialQueue _performNextFromRunLoopSource] + 45 25 CoreFoundation 0x0000000106e29301 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 17 26 CoreFoundation 0x0000000106e1f22c __CFRunLoopDoSources0 + 556 27 CoreFoundation 0x0000000106e1e6e3 __CFRunLoopRun + 867 28 CoreFoundation 0x0000000106e1e0f8 CFRunLoopRunSpecific + 488 29 GraphicsServices 0x0000000108ae7ad2 GSEventRunModal + 161 30 UIKit 0x0000000104a72f09 UIApplicationMain + 171 31 APPNAME 0x00000001013a26d2 main + 114 32 libdyld.dylib 0x0000000107b0d92d start + 1 33 ??? 0x0000000000000001 0x0 + 1 

)libc ++ abi.dylib:以NSExceptiontypes的未捕获exception终止

一步一步地运行我的代码,我发现错误发生在方法中:

 fbLoginManager.logInWithReadPermissions(permissionsNeeded, fromViewController: self) { (result, error) -> Void in //crashes before it enters this block //my code here } 

它甚至可以检查错误值之前崩溃。 我将尝试通过步入fbsdk方法并更新来检查值

fbsdk浏览器权限登录

只要我第二次按这个屏幕上的确定,它就会崩溃。 我怎样才能debugging呢? 该行动是不是在我的应用程序,它在浏览器中,所以我不知道从哪里去哪里..

最近我遇到了这个问题,我通过在Appdelegate.m中添加这段代码解决了这个问题。

 - (void)applicationDidBecomeActive:(UIApplication *)application { [FBSDKAppEvents activateApp]; } 

对于Swift 3版本:

 func applicationDidBecomeActive(_ application: UIApplication) { FBSDKAppEvents.activateApp() } 

更新到4.12,它根据他们的版本说明修复了这个问题:

https://developers.facebook.com/docs/ios/change-log-4.x/

说的部分:

固定

  • 修复了由于缺less会话ID而导致AppEvents可能崩溃的情况。
  • 修正了在某些情况下访问令牌到期date是刷新date的错误。

虽然这不一定是一个全面的解决scheme,但我已经耗尽了我的debugging方法。 我已经从我的pod文件中删除了FBSDK,运行pod update将它们从项目中删除,并在我的frameworks文件夹中重新安装了4.10版本的FBSDK。 当facebook发布FBSDK的更新版本后,我会再次尝试更新这个问题。