【发布时间】:2012-10-14 18:30:10
【问题描述】:
我正在尝试签署一个小程序,以便发布者不会显示为“UNKNOWN”:
我为一个组织工作,我们有我们自己的证书颁发机构,证书链如下:ORG 根 CA > ORG 受信任的证书颁发机构 > Yann39 (我 :D)
我申请了证书,他们为我提供了一个链接,可以将其放入浏览器。 然后我将它(从 Firefox)导出以获取我命名为 mystore.p12 的 PKCS#12 文件。
然后我做了以下操作来签署我的小程序:
/* TO KNOW THE ALIAS */
c:\testrep>keytool -list -storetype pkcs12 -keystore mystore.p12
Enter keystore password: ********
Keystore type: pkcs12
Keystore provider: SunJSSE
Your keystore contains 1 entry
id de yann39, Oct 24, 2012, keyEntry,
Certificate fingerprint (MD5): D7:E3:83:1D:C1:40:68:72:5F:A8:6F:AC:3A:EA:DD:47
/* CREATE FAKE CLASS FILE AND BUILD A JAR */
c:\testrep>echo test > test.class
c:\testrep>C:\oracle\dev10gr2\jdk\bin\jar cf0 test_applet.jar test.class
/* SIGN THE JAR */
c:\testrep>C:\oracle\dev10gr2\jdk\bin\jarsigner -verbose -storetype pkcs12 -keystore mystore.p12 test_applet.jar "id de yann39"
Enter Passphrase for keystore: ********
updating: META-INF/MANIFEST.MF
adding: META-INF/ID_DE_YA.SF
adding: META-INF/ID_DE_YA.RSA
signing: test.class
/* VERIFY THE SIGNATURE */
c:\testrep>C:\oracle\dev10gr2\jdk\bin\jarsigner -verify -verbose -certs test_applet.jar
132 Wed Oct 24 17:49:52 CEST 2012 META-INF/MANIFEST.MF
185 Wed Oct 24 17:49:52 CEST 2012 META-INF/ID_DE_YA.SF
4801 Wed Oct 24 17:49:52 CEST 2012 META-INF/ID_DE_YA.RSA
0 Wed Oct 24 17:48:36 CEST 2012 META-INF/
sm 0 Wed Oct 24 17:47:46 CEST 2012 test.class
X.509, CN=Yann39, CN=794324, CN=myname, OU=Users, OU=Organic Units,
DC=myorg, DC=ch
X.509, CN=ORG Trusted Certification Authority, DC=myorg, DC=ch
X.509, CN=ORG Root CA, DC=myorg, DC=ch
s = signature was verified
m = entry is listed in manifest
k = at least one certificate was found in keystore
i = at least one certificate was found in identity scope
jar verified.
c:\testrep>
然后我在我的应用程序中加载appled:
<object id="mytestapplet" width="0" height="0" style="position:absolute" type="application/x-java-applet">
<param name="archive" value="https://myhost.ch/rep/test_applet.jar">
<param name="code" value="test">
<param name="scriptable" value="true">
<param name="mayscript" value="no">
</object>
我读过一些类似这样的帖子:How to sign java applet with .pfx file? 并且似乎 我应该得到 smi 在验证来自 jar 的签名文件时,不仅是 sm 这意味着找不到证书在密钥库中。
所以我以为证书链不完整,但是在运行以下命令时,发现不是这样:
c:\testrep>keytool -list -v -storetype pkcs12 -keystore mystore.p12
Enter keystore password: ********
Keystore type: pkcs12
Keystore provider: SunJSSE
Your keystore contains 1 entry
Alias name: id de yann39
Creation date: Oct 24, 2012
Entry type: keyEntry
Certificate chain length: 3
Certificate[1]:
Owner: CN=Yann39, CN=794324, CN=myname, OU=Users, OU=Organic Units,
DC=myorg, DC=ch
Issuer: CN=ORG Trusted Certification Authority, DC=myorg, DC=ch
Serial number: 12d21eb200200000a02b
Valid from: Mon Jun 25 14:16:00 CEST 2011 until: Wed Jun 24 14:16:00 CEST 2013
Certificate fingerprints:
MD5: D7:E3:83:1D:C1:41:78:72:5F:A8:6D:BD:3A:ED:DD:48
SHA1: 24:31:1D:25:02:98:0D:F8:28:6A:F1:0E:E8:BB:04:7E:51:E2:E9:66
Certificate[2]:
Owner: CN=ORG Trusted Certification Authority, DC=myorg, DC=ch
Issuer: CN=ORG Root CA, DC=myorg, DC=ch
Serial number: 601fab4c000000000003
Valid from: Tue Oct 02 11:36:53 CEST 2006 until: Mon Oct 02 11:47:53 CEST 2016
Certificate fingerprints:
MD5: 51:A1:EA:33:21:2C:71:60:A1:6F:F1:22:92:A8:51:8D
SHA1: 66:CD:70:13:27:68:F3:C2:08:F3:BE:5F:BF:D4:17:BD:85:9D:10:65
Certificate[3]:
Owner: CN=ORG Root CA, DC=myorg, DC=ch
Issuer: CN=ORG Root CA, DC=myorg, DC=ch
Serial number: 7dc0d089138d1d804b2e68e21b947412
Valid from: Tue Oct 02 10:55:19 CEST 2006 until: Sat Oct 02 11:01:47 CEST 2026
Certificate fingerprints:
MD5: A2:CE:DC:7D:F5:60:D7:2C:5E:B5:29:74:9D:51:F9:49
SHA1: DA:D8:7F:63:95:90:A2:E4:D4:1D:B9:48:FD:F4:C3:5C:FC:2B:B6:A3
*******************************************
*******************************************
c:\testrep>
链条看起来不错。
但我仍然收到“未知”发布者的安全警告。 为什么?
2012 年 10 月 25 日编辑
我忘了说它使用 Internet Explorer 工作(“签名已被验证”并且发布者是“Yann39”),而不是使用 Chrome 或 Firefox。
我尝试使用自签名证书:
keytool -genkey -alias myalias -storetype PKCS12 -keystore mykeystore.p12 -dname "cn=Yann39, ou=UN, o=ORG, st=Geneva, c=CH"
keytool -list -v -storetype pkcs12 -keystore mykeystore.p12
echo test > test.class
C:\oracle\dev10gr2\jdk\bin\jar cf0 myapplet.jar test.class
C:\oracle\dev10gr2\jdk\bin\jarsigner -verbose -storetype pkcs12 -keystore mykeystore.p12 myapplet.jar "myalias"
C:\oracle\dev10gr2\jdk\bin\jarsigner -verify -verbose -certs myapplet.jar
IE 和 Firefox 或 Chrome 都不行,正常。
我尝试从我的组织添加 2 个受信任的证书,但失败了:
keytool -import -alias "myalias_root" -file ORGRooTCA.crt -storetype pkcs12 -keystore mykeystore.p12
keytool -import -alias "myalias_auth" -file ORGTrustedCertificationAuthority.crt -storetype pkcs12 -keystore mykeystore.p12
出现错误:
keytool error: java.security.KeyStoreException: TrustedCertEntry not supported
我仍然不明白为什么在验证签名时它说在密钥库(sm)中找不到证书。
编辑 2012 年 11 月 2 日
我终于收到了我的证书颁发机构的回复。由于提供代码签名证书仅用于测试(我们的组织未正式支持),因此它们不提供任何帮助并且关闭了我的票...
ORG Root CA 和 ORG 受信任的证书颁发机构 2 个证书在 3 种浏览器(IE、Firefox、Chrome)中受信任。运行我的小程序时,我仍然在 IE 中得到预期的结果:
- 名称:小程序测试
- 发布者:Yann39
- 发件人:https://myhost.ch
但不是在 Firefox 和 Chrome 中:
- 名称:测试
- 出版商:未知
- 发件人:https://myhost.ch
另一个奇怪的事情是,正如您所见,IE 将 HTML 中使用的 <object> 标记的 id 引用为“名称”(applettest),而 Firefox 和 Chrome 则引用了主类(test)。
我认为 Publisher 是一样的,IE 关注的是CN RDN (Yann39),而 Firefox 和 Chrome 关注的是O RDN 并且找不到,因为它没有在我的证书中定义。
如果有人有更多关于浏览器如何检查证书的信息,请分享。
谢谢。
【问题讨论】:
-
只是猜测,但小程序对话框可能使用证书的
O=RDN 来显示发布者是谁(浏览器就是这样做的)。如果您控制该 CA,您可以尝试将O=Something添加到您的主题 DN 以查看它是否会产生影响。 -
不幸的是,我无法控制 CA,他们只是为我提供了 PKCS12 文件。因为它只使用 Internet Explorer 才有效,也许其他浏览器正在寻找
O=而 IE 不关心它(像往常一样......)?我在帖子中添加了一些信息。 -
jar verified.哎呀!错过了。 -
进展如何?您是否成功验证发布者?
-
我已联系我的 CA 以获得任何帮助,并了解他们颁发给我的证书是否有任何问题(正如 Bruno 所建议的,它不包含
O=似乎很奇怪RDN。)。我还在等待回复,我会在获得更多信息后立即更新我的帖子。
标签: java ssl applet certificate signing