ホームページ  >  記事  >  Java  >  XML 署名検証のために Java のファイルから RSA 秘密キーをロードするにはどうすればよいですか?

XML 署名検証のために Java のファイルから RSA 秘密キーをロードするにはどうすればよいですか?

Patricia Arquette
Patricia Arquetteオリジナル
2024-10-25 09:42:28737ブラウズ

How to Load an RSA Private Key from a File in Java for XML Signature Verification?

Java でファイルから RSA 秘密キーをロードする

セキュリティ上の機密データを処理する場合、デジタル データの信頼性を検証できることが重要です署名。この場合のタスクは、ファイルから RSA 秘密キーをロードして XML 署名を検証することです。

これを実現するには、次の手順に従います。

1.秘密キー ファイルをバイトとして読み取ります:

<code class="java">String keyPath = "mykey.pem";
File privKeyFile = new File(keyPath);
BufferedInputStream bis = new BufferedInputStream(new FileInputStream(privKeyFile));
byte[] privKeyBytes = new byte[(int) privKeyFile.length()];
bis.read(privKeyBytes);
bis.close();</code>

2.秘密キーを PKCS8 形式に変換する (オプション)

秘密キーがまだ PKCS8 形式でない場合は、次のコマンドを使用して変換します。

<code class="bash">openssl pkcs8 -topk8 -inform PEM -outform DER -in private_key_file -nocrypt > pkcs8_key</code>

次に、変換されたキーを読み取ります。次のコードを使用します:

<code class="java">byte[] convertedPrivKeyBytes = Files.readAllBytes(Paths.get("pkcs8_key"));</code>

3. RSA 秘密キーを生成します:

<code class="java">KeyFactory keyFactory = KeyFactory.getInstance("RSA");
KeySpec ks = new PKCS8EncodedKeySpec(convertedPrivKeyBytes);
RSAPrivateKey privKey = (RSAPrivateKey) keyFactory.generatePrivate(ks);</code>

4.デジタル署名を検証します:

RSA 秘密キーを取得したら、それを使用して SAMLResponse オブジェクトの署名を検証できます:

<code class="java">samlResponse.sign(Signature.getInstance("SHA1withRSA").toString(), privKey, certs);</code>

次の手順に従って、ファイルから RSA 秘密キーを正常にロードし、それを使用してデジタル署名を検証できます。

以上がXML 署名検証のために Java のファイルから RSA 秘密キーをロードするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。