iOS 故障排除指南
要打造一个完美无缺的原生管理工具几乎是不可能的,你迟早会在 iOS 工作流的某个环节遇到各种问题。
本指南旨在记录常见的 iOS/Xcode 问题及其可能的解决方案。
iOS 工具箱
每位 iOS 开发者都会学到一些调试 iOS 问题的常用技巧,你应该将这些技巧融入你的工作流中:
善用搜索引擎
每当你在 iOS 或 Xcode 中遇到问题时,第一步应该是将错误信息复制并粘贴到搜索引擎中搜索。
Capacitor 使用的是标准的 iOS 工具链,因此如果你遇到了某个问题,很可能很多 iOS 开发者也曾遇到过,并且已经有了解决方案。
解决方法可能很简单,比如更新依赖、清理项目或删除派生数据。
清理/重新构建
清理并重新构建可以解决许多构建问题。在 Xcode 菜单中,导航至 Product -> Clean Build Folder 来清理当前的构建。
删除派生数据
有时,Xcode 会顽固地保留旧的、过时的构建产物。要重新开始,你需要删除磁盘上的所有派生数据。
为此,打开 Xcode 偏好设置,选择 Locations 标签页,然后点击 Derived Data 路径旁边的小箭头:

这将打开一个 Finder 窗口,显示 Xcode 的临时派生数据的位置。
接着,选择该目录中的所有项目并删除:

最后,在 Xcode 中执行一次重新构建。
错误:沙盒与 Podfile.lock 不同步
如果 CocoaPods 未能成功运行 以安装你的依赖项,可能会发生此错误。
运行以下命令来更新你的 pod:
npx cap update ios
运行此命令后,执行一次新的构建。
索引过程无休止
Xcode 有时会陷入无限索引的状态。这种不幸的情况看起来像这样:

唯一的解决方法是强制关闭 Xcode(使用活动监视器),然后重新启动它。
Apple Silicon:ffi 总线错误
如果你使用 sudo gem install cocoapods 安装了 CocoaPods,并且你使用的是 Apple Silicon 芯片的 Mac,在运行 npx cap update 时可能会遇到类似这样的错误:
[error] Analyzing dependencies
/Library/Ruby/Gems/2.6.0/gems/ffi-1.15.3/lib/ffi/library.rb:275: [BUG] Bus Error at 0x0000000000000000
ruby 2.6.3p62 (2019-04-16 revision 67580) [universal.arm64e-darwin20]
这是一个与 ffi 在 Apple Silicon 电脑上安装相关的 CocoaPods 错误。
我们建议使用 Homebrew 来安装 CocoaPods。
或者,如果你安装了 Rosetta,可以在 x86_64 架构下安装 ffi,并首次在模拟的 Intel 架构下运行 pod install。
$ sudo arch -x86_64 gem install ffi
$ arch -x86_64 pod install
之后,运行 Capacitor 应该就能正常工作了。
CocoaPods:无法连接到 GitHub
在安装了旧版本 openssl 和 ruby 的 Mac 上可能会出现此错误,因为 GitHub 在访问仓库时限制了允许的加密协议。
解决方案是更新 openssl 和 Ruby:
brew install openssl
brew upgrade openssl
brew install ruby
brew link --overwrite ruby
最后,确保你的 PATH 环境变量没有将 /usr/local/bin 放在 $PATH 之后,而是放在其之前。
有关此问题的其他可能解决方案,请参阅 此 StackOverflow 问题。
插件未实现
在 iOS 上,如果 Capacitor 找不到插件或无法将其代码注入到 WebView 中,可能会发生此问题。
首先,请确保插件已安装并出现在 package.json 中。
然后,运行 npx cap sync ios。
最后,检查插件是否在 ios/App/Podfile 中。如果未列出该插件,请确保你的 Podfile 看起来像这个示例,并再次运行 npx cap sync。
如果仍然收到“插件未实现”错误,请确保 ios/App/App/Info.plist 中没有 WKAppBoundDomains 键,该键会阻止 Capacitor 和插件代码的注入。如果不需要,请删除该键;如果无法删除,请在 capacitor 配置文件中的 ios 对象内添加 limitsNavigationsToAppBoundDomains 并将其值设为 true。