> Java > java지도 시간 > HTTPS를 통해 웹 서비스에 액세스할 때 'java.security.cert.CertificateException: 주체 대체 이름이 없습니다.' 오류를 수정하려면 어떻게 해야 합니까?

HTTPS를 통해 웹 서비스에 액세스할 때 'java.security.cert.CertificateException: 주체 대체 이름이 없습니다.' 오류를 수정하려면 어떻게 해야 합니까?

Linda Hamilton
풀어 주다: 2024-11-08 02:31:02
원래의
377명이 탐색했습니다.

How do I fix the

"java.security.cert.CertificateException: No subject Alternative names presents" 오류 수정

HTTPS를 사용하여 웹 서비스에 액세스할 때 Java 클라이언트에서 "java.security.cert.CertificateException: 주체 대체 이름이 없습니다." 오류가 발생하면 인증서의 주체 이름과 호스트 주소가 일치하지 않음을 나타냅니다.

이 문제를 해결하려면 다음 단계를 따르세요.

  1. "openssl s_client"의 출력에서 ​​"-----BEGIN CERTIFICATE-----"와 "-----END CERTIFICATE-----" 사이의 인증서 정보를 추출합니다. -showcerts -connect AAA.BBB.CCC.DDD:9443 -gt; certs.txt".
  2. "주체의 일반 이름(CN)" 필드가 IP 주소(AAA. BBB.CCC.DDD). 이는 OpenSSL의 "x509" 명령과 같은 도구를 사용하여 수행할 수 있습니다.
  3. "keytool -importcert -file fileWithModifiedCertificate"를 사용하여 수정된 인증서를 가져옵니다.

그러나 이 방법이 항상 그렇지 않을 수도 있습니다. 서버 인증서를 제어할 수 없는 경우 가능합니다.

대체 솔루션은 HTTPS 검사를 비활성화하는 것입니다. 이 접근 방식에는 모든 인증서를 허용하는 사용자 지정 신뢰 관리자 및 호스트 이름 확인 프로그램을 만드는 작업이 포함됩니다. "ISomeService" 클래스에 다음 코드를 추가합니다.

static {
    disableSslVerification();
}

private static void disableSslVerification() {
    // Create a trust manager that does not validate certificate chains
    TrustManager[] trustAllCerts = new TrustManager[] {new X509TrustManager() {
        public java.security.cert.X509Certificate[] getAcceptedIssuers() {
            return null;
        }
        public void checkClientTrusted(X509Certificate[] certs, String authType) {
        }
        public void checkServerTrusted(X509Certificate[] certs, String authType) {
        }
    }
    };

    // Install the all-trusting trust manager
    SSLContext sc = SSLContext.getInstance("SSL");
    sc.init(null, trustAllCerts, new java.security.SecureRandom());
    HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());

    // Create all-trusting host name verifier
    HostnameVerifier allHostsValid = new HostnameVerifier() {
        public boolean verify(String hostname, SSLSession session) {
            return true;
        }
    };

    // Install the all-trusting host verifier
    HttpsURLConnection.setDefaultHostnameVerifier(allHostsValid);
}
로그인 후 복사

보안 문제로 인해 프로덕션 환경에서는 HTTPS 검사를 비활성화하는 것이 권장되지 않습니다.

위 내용은 HTTPS를 통해 웹 서비스에 액세스할 때 'java.security.cert.CertificateException: 주체 대체 이름이 없습니다.' 오류를 수정하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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