我正在使用 Xcode 4.1 build 4B110f 试图让我的 iOS 应用程序准备好上传。它通过了 Product|Archive 步骤,没有任何错误,两次请求允许签署某些东西。但是当我尝试从组织者验证存档时,它失败了:
### Codesigning '/Users/uqrchern/Library/MobileDevice/Provisioning Profiles/70D2381D-3733-4F5D-88B2-4729572C2864.mobileprovision' with 'iPhone Distribution: Ron Chernich'
+ /usr/bin/codesign --force --preserve-metadata --sign iPhone Distribution: Ron Chernich --resource-rules=/var/folders/ul/ula1AHKnGpqQ9ftDnUL-l++++TM/-Tmp-/rybczU3EBd/Payload/ABRA-D.app/ResourceRules.plist --entitlements /var/folders/ul/ula1AHKnGpqQ9ftDnUL-l++++TM/-Tmp-/rybczU3EBd/entitlements_plistrZ1Vwko6 /var/folders/ul/ula1AHKnGpqQ9ftDnUL-l++++TM/-Tmp-/rybczU3EBd/Payload/ABRA-D.app
Program /usr/bin/codesign returned 1 : [/var/folders/ul/ula1AHKnGpqQ9ftDnUL-l++++TM/-Tmp-/rybczU3EBd/Payload/ABRA-D.app: replacing existing signature
/var/folders/ul/ula1AHKnGpqQ9ftDnUL-l++++TM/-Tmp-/rybczU3EBd/Payload/ABRA-D.app: object file format invalid or unsuitable
]
error: codesign failed with error 1
我查看了所有类似的问题和解决方案(其中一些毫无意义,或者适用于真正旧版本的工具)。没有人有丝毫不同。
我还检查了 3 次验证是否使用“生产”证书,生成存档的协同设计步骤也是如此。我什至把上面的输出变成了一个 schell 脚本,这样我就可以手动尝试所有的证书:每次都得到相同的结果。
也许正在签名的 .app 文件真的不合适?
顺便说一句,codesign 没有版本标志,但手册页的日期是 2006 年 6 月 1 日。二进制文件的文件日期是 2010 年 11 月 20 日。
更新(第二天):
研究该问题进一步发现了一个晦涩的参考资料,说 codesign 需要以下环境变量集:
CODESIGN_ALLOCATE=/Developer/Platforms/iPhoneOS.platform/Developer/usr/bin/codesign_allocate
使用失败的验证运行的输出,我创建了一个 shell 脚本,它在失败的 codesign --force 步骤和 viola 之前导出了这个 var!代码设计有效。
但这并不能真正帮助我准备上传代码。有没有办法将它包含到由 Organizer Validate 按钮运行的脚本中?
稍后,解决方案!:
根据理论,有一个脚本在某个地方生成了在 Organizer Validate... 运行期间运行的所有命令,我用 grep 和 find 进行了一些挖掘。该脚本确实存在,它的名称是:
/Developer/Platforms/iPhoneOS.platform/Developer/usr/bin/PackageApplication
这只是 Perl,解决方法是在开始时将所需的环境变量添加到关联数组 %ENV 中,例如在第 72 行:
$ENV{CODESIGN_ALLOCATE} = '/Developer/Platforms/iPhoneOS.platform/Developer/usr/bin/codesign_allocate';
这完全解决了问题。 我不知道网络上所有其他认为他们通过删除证书、构建清理、关闭和重新启动 Xcode 等组合来修复它的海报来自哪里。我只是悄悄地断言,这个修复有利于科学而不是迷信,并且在 Xcode 4.1 Build 4B110f 及其相关的 PackageApplication 脚本下对我有用,在带有 Perl 5.10.0 的 Snow Leopard 10.6.8 下运行