使用SPC文件在Linux上签名文件

时间:2011-07-28 14:26:57

标签: certificate key code-signing pem code-signing-certificate

我有一个.key文件,我从中生成了一个.csr文件,用于购买GoDaddy代码签名证书。从GoDaddy我收到一个.spc文件。

我使用以下命令将spc文件导出到pem:

openssl pkcs7 -inform DER -in mycert.spc -print_certs -out certs.pem 

然后我打开了certs.pem文件并将前两个证书复制到一个名为cert-chain.crt的文件中,将最后一个证书复制到一个名为server.crt的文件中。

我尝试使用此命令对文件进行签名:

openssl smime -sign -in a.mobileconfig -out signed_a.mobileconfig -signer cert/server.crt -inkey cert/ios_apn.key -certfile cert/cert-chain.crt -outform der -nodetach

但我得到的是:

unable to load certificate
11911:error:0906D06C:PEM routines:PEM_read_bio:no start line:/SourceCache/OpenSSL098/OpenSSL098-41/src/crypto/pem/pem_lib.c:648:Expecting: TRUSTED CERTIFICATE

我做错了什么?我应该如何使用提供的SPC文件正常签署a.mobileconfig文件?

1 个答案:

答案 0 :(得分:1)

您的证书是DER格式,但openssl采用PEM格式。您应该在命令中添加-inform der

openssl smime -sign -in a.mobileconfig -out signed_a.mobileconfig -signer cert/server.crt -inkey cert/ios_apn.key -certfile cert/cert-chain.crt -inform der -outform der -nodetach