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

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

Susan Sarandon
풀어 주다: 2024-11-11 01:26:02
원래의
598명이 탐색했습니다.

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿