Tauri 踩坑 appLink 修改后闪退
如题,Grok 救我狗命,我得重新苹果 Grok 搜索能力的优势了。 问题归根到底应该就是 Info.plist 没有在修改 appLink 之后自动更新,导致匹配不上。解决方案是清理掉原来的自动生成内容,重新运行 正确配置(tauri.conf.json): 常见写错导致闪退的几种情况: 彻底清理构建缓存: 删除 Xcode DerivedData(最重要): 重新生成/运行: 构建成功后,用模拟器测试: 总结:99% 是配置写错了(少了 ios init。估计不止这种问题,tauri + iOS 本来能正常跑,改了配置突然运行不了的情况,都可以尝试一下重新 init。这里还有点感悟,一旦出了舒适区,即使有 AI 也要花费不少时间解决这些问题,如果是熟练的 iOS 开发者应该一早就感应到这种问题了吧。1. “appLink”: false 的正确含义和用法
myapp://xxx),不需要服务器、不需要 .well-known 文件。CFBundleURLTypes。{
"plugins": {
"deep-link": {
"mobile": [
{
"scheme": ["myapp"], // ← 必须有这个,数组形式,方案名建议全小写
"appLink": false // 自定义 scheme 必须显式 false 或省略
}
// 如果你还想同时支持 Universal Link,可以再加一个对象
// {
// "host": "yourdomain.com",
// "pathPrefix": ["/open"]
// // appLink 默认 true,可不写
// }
]
}
}
}appLink: false 直接写在有 host 的对象里(混合使用)。appLink: false 却没写 scheme(插件生成空/无效的 CFBundleURLTypes)。"schemes",新版是 "scheme"(注意单数)。appLink 写在 deep-link 顶层而不是 mobile 数组里的对象里。2. 为什么会闪退?
com.apple.developer.associated-domains entitlement,切换到 false 后 entitlement 和 provisioning profile 不匹配,也会导致启动失败。3. 立即修复步骤(必做)
tauri ios clean # 如果有这个命令
# 或者手动
rm -rf target/ src-tauri/target src-tauri/gen/applerm -rf ~/Library/Developer/Xcode/DerivedDatatauri ios dev # 或 tauri ios buildCFBundleURLTypes,确认里面有你的 scheme,且没有空数组。4. 验证是否成功
xcrun simctl openurl booted myapp://testscheme 或混用了 host),导致 Info.plist 坏掉。改对配置 + 清理缓存基本就能解决。如果清理后还闪退,把你的 plugins.deep-link 那段完整配置贴出来,我再帮你看。