13

発行者が「 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? jarから署名されたファイルを検証するときに取得する必要が あるようです。それは、証明書がキ​​ーストアに見つからなかったことを意味するだけではありません。smism

そのため、証明書チェーンが完全ではないと思っていましたが、次のコマンドを実行すると、そうではないことがわかりました

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>

チェーンは良さそうです。

しかし、「UNKNOWN」 Publisherセキュリティ警告表示されます。なぜですか?


編集 2012 年 10 月 25 日

Chrome や Firefox ではなく、 Internet Explorer (「署名が検証されました」および発行元は「Yann39」) を使用して動作することを忘れていました。

自己署名証明書を使用してみました:

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 CAORG Trusted Certification Authorityの 2 つの証明書は、3 つのブラウザー (IE、Firefox、Chrome) で信頼されています。アプレットを実行すると、IE で期待どおりの結果が得られます。

しかし、Firefox と Chrome ではそうではありません:

<object>もう 1 つの奇妙な点は、ご覧のとおり、IE はHTML で使用されるタグの ID ( applettest )を「名前」として参照しているのに対し、Firefox と Chrome はメイン クラスの名前 ( test ) を参照していることです。

パブリッシャーについても同じことだと思います.IEはCNRDN(Yann39)を見ていますが、FirefoxとChromeはRDNを見ていOますが、証明書で定義されていないため、RDNを見つけることができません。

ブラウザが証明書をチェックする方法について詳しい情報をお持ちの方は、共有してください。

ありがとう。

4

4 に答える 4

10

独自の CA があり、その CA が発行した証明書を使用してアプレットに署名する場合は、その CA の証明書を信頼できる認証局のリストに追加する必要があります。

IE 内で実行する場合、Java プラグインは CA のシステム リストを使用できるようです。そのため、CA 証明書をシステム証明書ストレージに追加するだけで済みます (インポート中に証明書の宛先を信頼できる CA として手動で選択してください)。 )。

Chrome または Firefox 内で実行している場合、Java プラグインは何らかの理由でシステム証明書ストレージを使用せず、独自の個別の証明書ストレージのみを使用します。CA の証明書が Java プラグイン証明書ストレージに存在しない場合、「信頼できる CA」システム証明書ストレージにあるかどうかに関係なく、これらのブラウザでアプレットを実行すると、発行元が「UNKNOWN」であるという「安全でない」セキュリティ警告が表示されます。

証明書を Java プラグイン ストレージに追加するには、次の手順を実行します。

  • Java コントロール パネルを開く
  • 「セキュリティ」タブを選択
  • 「証明書の管理...」ボタンをクリックします
  • 「証明書タイプ」コンボボックスで「署名者 CA」オプションを選択します。
  • CA の証明書をインポートする

次回 Chrome または Firefox を使用してアプレットを実行すると、通常の「安全な」セキュリティ警告が表示され、そのアプレットを永久に信頼するオプションが表示されます。

于 2013-09-25T12:55:29.240 に答える
2

署名する前に、CA 証明書 (ルート CA まで) を p12 ファイルに追加する必要があります。

于 2013-02-12T19:52:26.430 に答える
2

署名証明書を変更したときに、同じ奇妙な「UNKNOWN」メッセージが表示されました。署名キーストアの証明書を cacerts にインポートしましたが (自己署名 jar が受け入れられるように)、Java キャッシュに古い jarfile が保持されていました。その後、「新しい」証明書で「古い」アプレットを起動すると、上記のようなメッセージが表示されました。

解決策: Java キャッシュをクリアします (Java コントロール パネルまたは javaws -uninstall を使用)。

これは、誰か (私のような) がこのエラー メッセージを検索しているときにこのスレッドに出くわした場合に備えてです。

于 2014-10-13T13:53:18.327 に答える
1

組織から 2 つの信頼できる証明書を追加しようとしましたが、失敗しました:

Emm ...証明書はインポートのみであるため、署名プロセスのデモを行うため、すべてが非常に不明確に思えます...

自己署名証明書を使用してみました IE でも Firefox でも Chrome でも正常に動作しません。組織から 2 つの信頼できる証明書を追加しようとしましたが、失敗しました:

もちろん、失敗しました。元のキー以外のキーのチェーンを取得するために証明書をインポートすることはできないためです。テストケースに戻ります...

あなたのテストケースで私が見ることができるのは、次のようなものです。

  • A) おそらくmyalias またはmyalias_rootmyalias_authキーを生成します - 詳細はこちら
  • B) ORGRooTCAORGTrustedCertificationAuthorityをインポートしようとする
  • C) テスト jar に署名しようとする

ステップ B では、2 つの証明書をインポートしようとします。だから私は尋ねなければならない

  • 2 つの証明書は、 myalias_root
    myalias_auth CSRを使用して生成されましたか?

そうでない場合は、次のようにいくつかの手順をスキップしただけだと思います。

  • A) Gen myalias_rootおよび myalias_authキー
  • B) myalias_root _root とmyalias_authの Gen CSR
  • C) myalias_rootおよびmyalias_auth CSR(s)を使用した生成証明書 ORGRooTCAおよび
    ORGTrustedCertificationAuthority
  • D)証明書をORGRooTCAおよびORGTrustedCertificationAuthorityとしてインポートしてチェーンを取得する
  • E) テスト jar に署名してみる

そしてもう一度…

組織から 2 つの信頼できる証明書を追加しようとしましたが、失敗しました:

その結果、私はあなたにアドバイスすることができます

  • A)組織から証明書を取得するだけでなく、証明書が生成されたキーストアキーも取得します
  • B) または、前述の ABCDE の手順に従って、独自のキーと独自の証明書を生成します:)

証明書を要求したところ、ブラウザに取得するためのリンクが提供されました。次に、それを (Firefox から) エクスポートして、mystore.p12 という名前の PKCS#12 ファイルを取得しました。

手動でインポートしてから、ここで説明されているようにエクスポートしましたか?

わかりました...それは非常に興味深いです。それでもpfxのすべてが正しいと確信している場合:Sそれでも、デモを使用してjarsignerを再生します。したがって、test_applet.jar に次のように署名します。

/* 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 

...かなり標準的な署名方法ですが、少し詳しく説明したいと思います...jarsignerが「id de yann39」秘密鍵パスワードの入力を要求する場所がわかりません:S ? 私が見ることができるのは、キーストアのパスワードのみを入力することだけです...コピーアンドペーストバージョンでステップがスキップされていますか、それともjarsignerは本当にキーパスワードの入力を要求していませんか?

試しに、-keypass arg as を使用して jar に署名することをお勧めします (例を参照) 。

jarsigner -keystore C:\working\mystore -storepass myspass
      -keypass dukekeypasswd MyJarFile.jar duke

詳細については、jarsignerドキュメントの使用方法を参照してください...


証明書に変更を加えていないので、元の秘密鍵だと思いますか? あなたの編集について:はい、あなたのリンクに記載されているようにエクスポートしましたが、「バックアップ」のみではなく「すべてバックアップ」を使用しました。.jar ファイルへの署名について、私は何もスキップしませんでした。jarsigner は、キーストアのパスワードを要求するだけです。キーストアのパスワードと秘密鍵のパスワードは同じだと思いますが、

keytool を使用してキーストアでキーを生成した場合、キーストアにはパスワードがあり、新しく生成された秘密キーには独自のパスワードが必要であることを知っておく必要があります。したがって、ここに何かが欠けている可能性があると思います:S 興味深いでしょう A)ここで説明されているように、pfx を IE にインポートし、IE でエクスポートします。もし可能なら"

PSそれが役に立ったらコメントしてください

于 2012-10-27T23:28:54.730 に答える