40

我正在使用 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 下运行

4

3 回答 3

8

只是这样可以将其从未答复的列表中删除。就像你说的,你需要添加CODESIGN_ALLOCATE$ENV数组中:

$ENV{CODESIGN_ALLOCATE} = '/Developer/Platforms/iPhoneOS.platform/Developer/usr/bin/codesign_allocate';

如果大家在这里都同意的话,我想这个问题终于可以结束了。

使用更新版本的 Xcode 时,默认位置是:

$ENV{CODESIGN_ALLOCATE} = '/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/usr/bin/codesign_allocate';
于 2011-12-04T03:56:11.960 回答
1

如果你在最新版本的 Xcode 上得到这个,你真正想要的是,在 shell 中:

export CODESIGN_ALLOCATE=`xcode-select -print-path`/Platforms/iPhoneOS.platform/Developer/usr/bin/codesign_allocate

它将使用您正在使用的 Xcode 版本中的 codesign_allocate 。

您可以通过运行 xcode-select -switch 来更新命令行工具使用的 Xcode 版本

于 2013-09-02T14:56:07.213 回答
0

这个解决方法我已经使用了很长时间,但是在使用 iOS 5.1 SDK 升级到 Xcode 4.3 后,我的签名脚本(调用codesign)停止工作并出现cannot find code object on disk错误:

output/Enterprise/Payload/MyProduct.app/MyProduct: replacing invalid existing signature    
output/Enterprise/Payload/MyProduct.app/MyProduct: cannot find code object on disk     
Code signing failed, not creating .ipa file    

对于使用 Xcode 4.3 构建的二进制文件,似乎不需要这种解决方法。为了解决这个问题,我更新了我的 bash 脚本,以在导出之前检查该位置是否存在:

  # Only export the environment variable if the location exists,
  # otherwise it breaks the signing process!
  if [ -f "/Developer/Platforms/iPhoneOS.platform/Developer/usr/bin/codesign_allocate" ]
  then
    echo Export environment variable for codesign_allocate location
    export CODESIGN_ALLOCATE=/Developer/Platforms/iPhoneOS.platform/Developer/usr/bin/codesign_allocate
  fi
于 2012-04-05T18:34:49.893 回答