PEM BASE64로 인코딩된 개인 키 파일에서 RSA 개인 키 가져오기
PEM BASE64로 인코딩된 개인 키 파일에서 개인 키를 추출하려고 할 때 , 설명한 것과 같은 오류가 발생할 수 있습니다. 이는 일반적으로 비표준 키 형식 사용으로 인한 키 사양의 부적절한 처리로 인해 발생합니다.
오류 해결
발생하는 오류는 다음과 같습니다. 개인 키를 구문 분석하는 데 잘못된 방법을 사용하는 것과 관련이 있을 수 있습니다. 잠재적으로 FIPS를 준수하지 않는 타사 라이브러리에 의존하는 대신:
sun.security 및 DerInputStream을 사용하여 업데이트된 Java 코드:
다음은 다음을 사용하는 업데이트된 Java 코드 조각입니다. FIPS 준수를 보장하면서 개인 키의 PKCS#1 및 PKCS#8 형식을 모두 구문 분석하는 sun.security 및 DerInputStream 클래스:
import sun.security.util.DerInputStream; import sun.security.util.DerValue; import java.io.File; import java.io.IOException; import java.math.BigInteger; import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.Paths; import java.security.GeneralSecurityException; import java.security.KeyFactory; import java.security.PrivateKey; import java.security.spec.PKCS8EncodedKeySpec; import java.security.spec.RSAPrivateCrtKeySpec; import java.util.Base64; public static PrivateKey pemFileLoadPrivateKeyPkcs1OrPkcs8Encoded(File pemFileName) throws GeneralSecurityException, IOException { // ... (code as shown in the question) }
오류 및 해결 방법에 대한 자세한 설명:
원본 코드 조각은 IBM FIPS 제공자를 사용하여 개인 키를 구문 분석하려고 시도했는데 이는 가장 적절한 방법이 아닐 수 있습니다. 업데이트된 코드는 sun.security 및 DerInputStream 클래스와 함께 보다 표준화된 접근 방식을 사용하여 PKCS#1 및 PKCS#8 형식을 모두 처리합니다. 이렇게 하면 FIPS 규정 준수가 보장되고 발생한 오류가 해결됩니다.
위 내용은 Java의 PEM 파일에서 PKCS#1 및 PKCS#8 개인 키를 구문 분석하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!