>Java >java지도 시간 >Java의 PEM BASE64 인코딩 개인 키 파일에서 RSA 개인 키를 추출하는 방법은 무엇입니까?

Java의 PEM BASE64 인코딩 개인 키 파일에서 RSA 개인 키를 추출하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-11 01:26:02608검색

How to Extract an RSA Private Key from a PEM BASE64 Encoded Private Key File in Java?

PEM BASE64로 인코딩된 개인 키 파일에서 RSA 개인 키 얻기

특정 시나리오에서는 RSA 개인 키를 추출해야 할 수도 있습니다. PEM BASE64로 인코딩된 개인 키 파일에서. Java의 내장 기능으로 인해 키를 디코딩하려고 하면 "InvalidKeySpecException" 오류가 발생할 수 있습니다. 이 문제를 해결하려면 다음 단계를 고려하세요.

1. PKCS 형식 이해:

개인 키에는 PKCS#1과 PKCS#8이라는 두 가지 일반적인 PKCS 형식이 있습니다. PKCS#1은 이전 버전이며 파일 확장자 ".pem"으로 표시되는 반면, PKCS#8은 최신 버전이며 일반적으로 ".key" 확장자를 사용합니다.

2. 키 파일의 PEM 형식 식별:

개인 키 파일 내의 콘텐츠를 검사합니다. "-----BEGIN PRIVATE KEY-----"로 시작하고 "-----END PRIVATE KEY-----"로 끝나는 경우 PKCS#8 형식입니다. "-----BEGIN RSA PRIVATE KEY-----"로 시작하고 "-----END RSA PRIVATE KEY-----"로 끝나는 경우 PKCS#1 형식입니다.

3. 적절한 Java 코드 선택:

개인 키 파일 형식에 따라 제공된 해당 코드 조각을 사용하세요.

PKCS#8 형식의 경우:

byte[] pkcs8EncodedKey = Base64.getDecoder().decode(privateKeyPem);

KeyFactory factory = KeyFactory.getInstance("RSA");
PrivateKey privateKey = factory.generatePrivate(new PKCS8EncodedKeySpec(pkcs8EncodedKey));

PKCS#1의 경우 형식:

DerInputStream derReader = new DerInputStream(Base64.getDecoder().decode(privateKeyPem));
DerValue[] seq = derReader.getSequence(0);
BigInteger modulus = seq[1].getBigInteger();
BigInteger publicExp = seq[2].getBigInteger();
BigInteger privateExp = seq[3].getBigInteger();
// ... Continue extracting the remaining components and construct the RSAPrivateCrtKeySpec

KeyFactory factory = KeyFactory.getInstance("RSA");
PrivateKey privateKey = factory.generatePrivate(keySpec);

이러한 단계를 따르고 적절한 Java 코드 조각을 사용하면 PEM BASE64로 인코딩된 개인 키 파일에서 RSA 개인 키를 성공적으로 가져와 특정 요구 사항에 맞게 활용할 수 있습니다.

위 내용은 Java의 PEM BASE64 인코딩 개인 키 파일에서 RSA 개인 키를 추출하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.