配置应用时出现Firebase错误 - 无法识别的选择器已发送至课程

时间:2017-02-10 22:49:43

标签: ios xcode firebase

我在iOS应用中使用Firebase并拥有两个单独的Firebase项目,一个用于生产,另一个用于开发。我的两个.plist文件是GoogleService-Info.plistGoogleService-Info-Dev.plist,我可以根据目标中设置的标记选择这些文件 - >构建设置 - >其他Swift Flags。

内部AppDelegate didFinishLaunchingWithOptions

#if DEBUG
    let buildFor = "DEV"
#else
    let buildFor = "PROD"
#endif
let firebasePlistFileName = buildFor == "DEV" ? "GoogleService-Info-Dev" : "GoogleService-Info"
let firebaseOptions = FIROptions(contentsOfFile: NSBundle.mainBundle().pathForResource(firebasePlistFileName, ofType: "plist"))
FIRApp.configureWithOptions(firebaseOptions) // line causing new Firebase error

直到今天,当我遇到另一个Cocoapod项目的问题时,这一直很好。我认为当我清理Xcode项目或删除Derived Data文件夹时,它开始发生了:

dyld: Library not loaded: @rpath/OtherPod.framework/OtherPod
  Referenced from:
  /Users/me/Library/Developer/CoreSimulator/Devices/12345678-E1C4-480F-B1D9-C10823DEA810/data/Containers/Bundle/Application/AE7B6EB0-43AB-CCCC-BBBB-AAAA71BF/MyApp.app/MyApp
  Reason: image not found

我最终通过选择目标下的应用程序解决了这个问题 - >一般 - >链接的框架和库,然后在Workspace文件夹(7个其他pod项目)中添加所有选项,并将我添加的那些选项设置为可选项。从那时起,我一直面临着这篇文章标题中描述的错误:

2017-02-10 17:19:29.660 MyApp[12639:182433] +[NSData gtm_dataByGzippingData:error:]: unrecognized selector sent to class 0x10a0442e8
2017-02-10 17:19:29.680 MyApp[12639:182433] *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '+[NSData gtm_dataByGzippingData:error:]: unrecognized selector sent to class 0x10a0442e8'
*** First throw call stack:
(
  0   CoreFoundation                      0x0000000109d88d4b __exceptionPreprocess + 171
  1   libobjc.A.dylib                     0x00000001097f121e objc_exception_throw + 48
  2   CoreFoundation                      0x0000000109df8e44 +[NSObject(NSObject) doesNotRecognizeSelector:] + 132
  3   CoreFoundation                      0x0000000109d0e005 ___forwarding___ + 1013
  4   CoreFoundation                      0x0000000109d0db88 _CF_forwarding_prep_0 + 120
  5   MyApp                               0x0000000102d73c9d -[FIRNetwork postURL:payload:queue:usingBackgroundSession:completionHandler:] + 331
  6   MyApp                               0x0000000102d70e72 -[FIRClearcutLogger sendNextPendingRequestWithCompletionHandler:] + 570
  7   MyApp                               0x0000000102d70918 -[FIRClearcutLogger sendLogsWithCompletionHandler:] + 447
  8   libdispatch.dylib                   0x000000010a6ab978 _dispatch_call_block_and_release + 12
  9   libdispatch.dylib                   0x000000010a6d50cd _dispatch_client_callout + 8
  10  libdispatch.dylib                   0x000000010a6b2e17 _dispatch_queue_serial_drain + 236
  11  libdispatch.dylib                   0x000000010a6b3b4b _dispatch_queue_invoke + 1073
  12  libdispatch.dylib                   0x000000010a6b402b _dispatch_queue_override_invoke + 683
  13  libdispatch.dylib                   0x000000010a6b6385 _dispatch_root_queue_drain + 720
  14  libdispatch.dylib                   0x000000010a6b6059 _dispatch_worker_thread3 + 123
  15  libsystem_pthread.dylib             0x000000010aa3a712 _pthread_wqthread + 1299
  16  libsystem_pthread.dylib             0x000000010aa3a1ed start_wqthread + 13
)
libc++abi.dylib: terminating with uncaught exception of type NSException

我尝试了很多不同的修补程序,包括adding to the Link Binary with Librariesadding to the Other Linker Flags,但没有一个有效。

无法识别的选择器可能是什么,以及如何更改/删除它?这个问题可能是由于我面临的早期问题(库没有加载)吗?

为了澄清,当发生unrecognized selector sent to class错误时,Xcode调试导航器将专注于线程7,并突出显示FIRApp.configureWithOptions(firebaseOptions)行。

更新

我通过恢复到之前的git提交(将我的存储库克隆到一个单独的目录中)找到了一个临时修复,然后使用当前生成错误的副本替换了旧提交中的大部分项目内容,包括根目录中的App-Name 文件夹, App-Name .xcodeproj和 App-Name .xcworkspace。我只在模拟器(运行iOS 10.2的iPhone 7)上进行了测试,这很有效。然后我成功地向iTunes Connect提交了一个版本,并且能够在我的设备上运行该版本(带有10.2.1的iPhone 5c),但在删除它并尝试从Xcode运行构建之后,我再次遇到了同样的错误。但是,在模拟器上运行时出现错误。这与在物理设备和模拟器上发生的初始错误情况形成对比。

这让我记得我最初发布的堆栈跟踪是在模拟器上运行应用程序的跟踪。在设备上运行它会产生较少的输出,特别是*** First throw call stack:之后的内容仅为(0x1d01cdf7 0x1c27f077 0x1d022467 0x1d020579 0x1cf453d8 0x31ff3f 0x31d653 0x31d05d 0x1c57d57 0x1c63e63 0x1c5b205 0x1c64391 0x1c65d9f 0x1c65ba7 0x1c877937 0x1c877490),而不是具有文件/函数名称的更具描述性的输出。

4 个答案:

答案 0 :(得分:13)

我遇到了同样的问题,重新安装pods确定了问题。

请按照以下步骤解决问题。

请确保您已在Other Linker Flags.

中添加了添加两个参数
$(inherited)
-ObjC

<强>解决方案: 只需在项目中再次安装可可豆荚即可。请参阅以下命令以删除和安装pod。

 - Remove all Framework from Project using Below command.

   1.  pod deintegrate
   2.  pod clean

 - Install pod file Again.
   1. pod install
  

您的项目遇到了参考问题(未找到框架   特定目录)。

清理和构建项目。

答案 1 :(得分:4)

确保GoogleToolboxForMac广告连播中的GTMNSData + zlib.m仍在构建并链接到您的应用中。

enter image description here

确保-ObjC和-framework GoogleToolboxForMac位于链接日志中:

enter image description here

答案 2 :(得分:0)

在尝试手动添加firebase框架时遇到此问题的任何人。我遇到了相同的问题,这是由不同版本的Firebase引起的。我尝试按照自述文件的建议添加其他框架,但是遇到了上述错误。

我通过从项目和构建阶段中删除所有的firebase框架来解决此问题。下载了最新版本,并将所有框架重新添加到项目中,问题已解决。

答案 3 :(得分:0)

我刚刚输入了 pod update,然后关闭并重新打开了 Xcode。为我工作。