> Java > java지도 시간 > Java의 PEM 파일에서 PKCS#1 및 PKCS#8 개인 키를 구문 분석하는 방법은 무엇입니까?

Java의 PEM 파일에서 PKCS#1 및 PKCS#8 개인 키를 구문 분석하는 방법은 무엇입니까?

Barbara Streisand
풀어 주다: 2024-11-09 00:28:01
원래의
1033명이 탐색했습니다.

How to Parse PKCS#1 and PKCS#8 Private Keys from a PEM File in Java?

PEM BASE64로 인코딩된 개인 키 파일에서 RSA 개인 키 가져오기

PEM BASE64로 인코딩된 개인 키 파일에서 개인 키를 추출하려고 할 때 , 설명한 것과 같은 오류가 발생할 수 있습니다. 이는 일반적으로 비표준 키 형식 사용으로 인한 키 사양의 부적절한 처리로 인해 발생합니다.

오류 해결

발생하는 오류는 다음과 같습니다. 개인 키를 구문 분석하는 데 잘못된 방법을 사용하는 것과 관련이 있을 수 있습니다. 잠재적으로 FIPS를 준수하지 않는 타사 라이브러리에 의존하는 대신:

sun.security 및 DerInputStream을 사용하여 업데이트된 Java 코드:

다음은 다음을 사용하는 업데이트된 Java 코드 조각입니다. FIPS 준수를 보장하면서 개인 키의 PKCS#1 및 PKCS#8 형식을 모두 구문 분석하는 sun.securityDerInputStream 클래스:

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

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