我们购买了用于签署applet的代码签名证书,但签署applet时出现以下错误。
C:\CM\WEB-INF>jarsigner -keystore code_signing.keystore C:\CM\SweetApplet.jar code_signing_real
Enter Passphrase for keystore:
jarsigner: Certificate chain not found for: code_signing_real. code_signing_real must reference a valid KeyStore key entry containing a private key and corresponding public key certificate chain.
我们的证书不正确吗?这是以下问题的证书。错误消息似乎表明证书必须包含私钥,但我们不明白这是怎么回事,因为私钥永远不会暴露给除我们以外的任何人。
C:\CM\WEB-INF>keytool -list -keystore code_signing.keystore -alias code_signing_real -v
Enter keystore password:
Alias name: code_signing_real
Creation date: Mar 13, 2014
Entry type: trustedCertEntry
Owner: CN=CE, OU=CE, O=CE, L=PAL
O ALTO, ST=California, C=US
Issuer: CN=Thawte Code Signing CA - G2, O="Thawte, Inc.", C=US
Serial number: 728b78e4ded46af26494c59690e428f0
Valid from: Wed Mar 12 17:00:00 PDT 2014 until: Fri Mar 11 15:59:59 PST 2016
Certificate fingerprints:
MD5: E0:DB:9E:DC:37:1E:C2:A9:EA:C0:A8:21:22:61:9F:DD
SHA1: F9:C3:75:37:CA:86:4D:E2:11:BE:52:79:CE:FA:B3:6B:32:F0:CF:D2
Signature algorithm name: SHA1withRSA
Version: 3
Extensions:
#1: ObjectId: 2.5.29.19 Criticality=true
BasicConstraints:[
CA:false
PathLen: undefined
]
#2: ObjectId: 1.3.6.1.5.5.7.1.1 Criticality=false
AuthorityInfoAccess [
[accessMethod: 1.3.6.1.5.5.7.48.1
accessLocation: URIName: http://ocsp.thawte.com]
]
#3: ObjectId: 2.5.29.4 Criticality=false
#4: ObjectId: 2.5.29.31 Criticality=false
CRLDistributionPoints [
[DistributionPoint:
[URIName: http://cs-g2-crl.thawte.com/ThawteCSG2.crl]
]]
#5: ObjectId: 2.5.29.37 Criticality=false
ExtendedKeyUsages [
codeSigning
1.3.6.1.4.1.311.2.1.22
]
#6: ObjectId: 2.16.840.1.113730.1.1 Criticality=false
NetscapeCertType [
Object Signing
]
答案 0 :(得分:2)
它并不表示证书必须包含私钥。证书不包含私钥。再读一遍。它说密钥条目必须包含私钥和证书。
所以你构建了这个KeyStore,它是无效的。您可能只是将签名证书导入到新的KeyStore中,或者使用新别名。您必须将其导入到私钥的原始KeyStore中,并使用与私钥相同的别名。
您还必须将证书链作为可信CA证书导入另一个别名。