iOS:找不到嵌入式框架,但仅在*某些*安装中

标签 ios iphone xcode frameworks

我的应用程序的当前 AppStore 版本导致数百名用户崩溃,因为找不到捆绑的框架。这在测试中没有出现,而且我一直无法重现这个问题,无论是在模拟器上还是在设备上,无论我是将设备擦干净并进行全新安装,还是在现有版本上安装。

我从用户那里得到的错误日志表明:

Dyld Message: Library not loaded: @rpath/OMGHTTPURLRQ.framework/OMGHTTPURLRQ
Referenced from: /var/containers/Bundle/Application/BB320110-3C64-4772-9A3A-208F4CAD84B5/PicTapGo.app/PicTapGo
Reason: image not found

但是,经过审查,该框架肯定包含在发送到 App Store 的实际包中,位于 Frameworks 文件夹中。在 Xcode 项目中,运行时搜索路径包括“@executable_path/Frameworks”,这是捆绑框架的地方。

这是我们第一次链接动态库(这是必须的,因为该库包含 Swift 代码),所以我可能(甚至可能)遗漏了一些关于嵌入式框架的重要信息.

同样,奇怪的是,我可以将我的 iPhone 擦干净,然后从 App Store 重新安装这个版本,并且不会出现错误。在我测试过的每个配置中(包括我们的 Beta 测试人员),库加载得很好。这意味着只有部分用户缺少该框架。此外,失败似乎没有任何韵律或原因。它发生在各种 iOS 设备上,在所有版本的 iOS 9 上(尽管我没有在 Xcode 管理器中看到任何 iOS 8 崩溃列表)。我完全无法重现该问题,但对于受影响的用户来说,它一直在发生。

知道为什么只有 一些 设备无法找到捆绑的框架吗?在某些情况下,App Store 是否会干扰您的 bundle 配置?

最佳答案

经过一些调查,这些库似乎确实 消失了。窥探发送到 App Store 的实际库二进制文件,它们最终只为 arm64 构建。仍在研究这是如何发生的(可能是一些 CocoaPods 的怪异),但这巧妙地解释了 dyld 在野外的失败。对于 arm64 架构(iPhone 5s 及更高版本),一切正常。对于 4s、5、5c 和更旧的 iPad,dyld 无法找到该库。显然,App Store strips out non-compatible architectures当他们处理应用程序时, bundle 的那部分在 armv7 设备上完全缺失。查看可用的崩溃报告,它们都不是在 arm64 设备上。

所有“找不到库”的崩溃,以及上面提到的日志,都发生在 iOS9 上。 iOS 8 上也有类似的崩溃,但消息不同。我假设它是我能够在本地复制的那个(“no suitable image found... Did find <somelib>: mach-o, but wrong architecture”),这与 iOS8 设备将获得完整的 fat 二进制文件的想法相吻合。 Lib 会在那里,但没有 arm7。

iOS Architectures by device

这种故障在正常开发过程中并不明显。我使用 iPhone 6 作为主要测试设备,我的测试团队显然也在使用更新的设备。我曾依靠模拟器在旧设备上进行测试。至少出于我现在可以引用的一个原因,这看起来像是一个 Bad Idea™。将来,我将在实际的 armv7 设备上进行测试,然后再将其发送到世界上。

因此,对于任何在未来遇到 dyld 故障的人来说,这是另一件需要寻找的事情。如果事实并非如此,将对此进行更新。

编辑:尸检的另一个花絮,为了后代——我们最终在 AppStore 构建中使用 arm64-only 的方式是捆绑库的调试版本,而不是 AppStore 版本。我通过创建一个新的 Copy 阶段并从 CocoaPods 的 Products 组拖拽框架来捆绑框架。但是,以这种方式配置复制阶段时获得的实际二进制文件取决于您当前处于事件状态的方案。如果您有一个激活的调试方案,您将获得库的调试版本。如果您有一个 AppStore 方案处于事件状态,您将获得一个 AppStore 构建。这是 Xcode 项目中的硬编码路径,无论您将来为主项目的构建选择哪种方案,都将捆绑您最初拖动的版本。

默认情况下,调试构建仅构建事件架构,这意味着调试库缺少 armv7 支持。

关于iOS:找不到嵌入式框架,但仅在*某些*安装中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37513448/

相关文章:

ios - 带有 UIControlEventTouchDown 的 UIButton,在手指抬起之前图像不会更改为选中状态

ios - 能运行成功但不能存档?

ios - 缺少闭包默认初始值设定项 - 快速闭包变量声明?

ios - 无法从 UIViewController 基类继承属性

iphone - 在 UITextView 中连续退格许多字符

ios - 使用现有数据导入 Magical Record

ios - 如何使用自动布局用多个 UILabel 填充 UITableViewCell

iphone - iCarousel 的索引

iphone - SentTestCase 不会将 UnitTest 失败突出显示为代码中的错误

iphone - ABMultiValueRef 上的 iOS 地址簿错误