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