이 기사에서는 Java의 파일에서 RSA 공개 키를 로드하는 방법에 대해 설명합니다. 이 시나리오는 OpenSSL을 사용하여 개인 키와 공개 키 쌍을 생성하고 이를 디지털 서명 및 확인 목적으로 Java에서 사용하려고 할 때 발생합니다.
개인 키를 변환할 수 있습니다. OpenSSL을 사용하여 PKCS8 형식으로 변환한 후 다음 코드를 사용하여 로드합니다.
<code class="java">import java.nio.file.*; import java.security.*; import java.security.spec.*; public class PrivateKeyReader { public static PrivateKey get(String filename) throws Exception { byte[] keyBytes = Files.readAllBytes(Paths.get(filename)); PKCS8EncodedKeySpec spec = new PKCS8EncodedKeySpec(keyBytes); KeyFactory kf = KeyFactory.getInstance("RSA"); return kf.generatePrivate(spec); } }</code>
공개 키를 로드하려면 X509 형식으로 변환해야 합니다. 코드 조각은 다음과 같습니다.
<code class="java">import java.nio.file.*; import java.security.*; import java.security.spec.*; public class PublicKeyReader { public static PublicKey get(String filename) throws Exception { byte[] keyBytes = Files.readAllBytes(Paths.get(filename)); X509EncodedKeySpec spec = new X509EncodedKeySpec(keyBytes); KeyFactory kf = KeyFactory.getInstance("RSA"); return kf.generatePublic(spec); } }</code>
이 단계를 따르면 파일에서 RSA 공개 키와 개인 키를 모두 성공적으로 로드하고 서명 및 확인 작업에 사용할 수 있습니다.
위 내용은 Java의 파일에서 RSA 공개 키를 로드하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!