sitelink1 http://ggangpark.blog.me/60068318769 
sitelink2  
sitelink3  
sitelink4  
sitelink5  
sitelink6  

웹서버에서 종종 중요한 정보교환을 위해 SSL을 사용하곤 한다.

이번의 경우는 HttpsURLConnection을 통해 SSL연결을 하는데 있어 문제되었던 사항이다.

 

<환경>

- Tomcat 5.5

- Apache 2.0 OpenSSL 포함 버전

- J2EE 5.X

 

<문제>

SSL연결시 아래와 같은 Exception이 발생했다.

javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target

 

javax.net.ssl.SSLHandshakeException 은 접속하려는 SSL서버에 유효한 인증서가 없는 경우를 의미한다.

이러한 인증서의 위치는 %JRE_HOME%\lib\security 에 cacerts 파일로 존재한다. 

즉, 이파일에 현재 접속하려는 SSL서버의 인증서가 존재하지 않는것이다.

 

<해결>

첨부된 InstallCert.java을 열면 소스 상단부분에

/************** 소스 24째줄 ***************/

String host = "127.0.0.1"//SSL서버의 도메인이나 IP
 int port = 443;

 

위와같이 host를 설정하는 부분이 있다. host에는 접속하려는 SSL서버의 IP나 도메인을 설정한다.

이소스는 java.net.ssl.SSLHandshakeException이 발생하면 해당 서버에서 인증서를 받아 파일로

저장해주는 역할을 한다.

 

컴파일하고 클래스를 실행하면 전과같이 java.net.ssl.SSLHandshakeException이 발생하고 class와 동일한 위치에 jssecacerts

라는 인증서 파일이 생성된다. 이 파일을 J2EE 5 설치시 생성됬던 %JRE_HOME%\lib\security 에 넣어주면 완료된다.

기존의 cacerts파일에 인증서가 존재하지 않으면 jssecacerts에서 찾는다고 한다.

 

 

*주의*

J2EE설치시 jdk안에 있는 jre와 jdk root와 동일한 위치에 있는 jre가 존재할 수 있다.

본인의 경우엔 후자에 인증서 파일을 넣어 주었다.

인증서가 있어 생기는 문제는 없으므로 둘다 넣어주는것도 나쁘지 않다.

 

************************************************************************************************

naver과 google를 상당히 찾아 봤지만 쓸모 있었던건 단하나의 사이트 밖에 없었다.

그 역시 너무 간단히 설명 되어있어 멍청한 나로선 이해하기 좀 힘들었다.  -_-;;

수차례 실패하고 애꿎은 Apache에 SSL설치하고.....무료인증서 받고.......ㅠㅠ

문제의 요지를 파악하지 못한 경우였다.

 

문제는 SSL서버는 따로 존재했기때문에 웹서버에 SSL을 설치할 필요가 없었고

웹서버의 문제가 아닌 java로 연결핼때 생기는 문제였으므로 java에서 해결봤어야 했다.

해결법을 찾아 해매다 이글을 보신분이 조금이라도 도움이 됬으면 한다.

번호 제목 글쓴이 날짜 조회 수
251 Calendar, Date, Format, java.time 패키지 황제낙엽 2017.10.31 108
250 날짜, 시간 문자열 값으로 Date 오브젝트로 만들기 >> SimpleDateFormat("EEE MMM dd HH:mm:ss z yyyy", Locale.US) 황제낙엽 2017.10.31 1516
249 시스템 속성(System Property) 클래스를 이용하여 jni 라이브러리 사용하기 황제낙엽 2017.09.22 37
248 Java 실행 옵션들 황제낙엽 2017.08.23 3367
» HttpsURLConnection 을 사용한 SSL서버 접속 file 황제낙엽 2017.08.02 231
246 서버구동시 주기적으로 동작을 수행하는 스레드를 함께 실행하는 서블릿 황제낙엽 2017.08.02 131
245 HttpURLConnection 사용 샘플( JSP , SERVLET ) 황제낙엽 2017.08.01 254
244 HttpURLConnection 사용하기 황제낙엽 2017.08.01 393
243 [HttpURLConnection] POST로 파라미터 넘기기 황제낙엽 2017.08.01 507
242 HttpURLConnection POST 방식 사용하기 황제낙엽 2017.08.01 370
241 Runtime 클래스를 이용한 윈도우 프로그램 실행 예제 황제낙엽 2017.08.01 113
240 JSON Util (JSON 을 다루기 위해 직접 작성한 유틸 클래스) file 황제낙엽 2017.07.10 461
239 자바 리플렉션(Java Reflection) 간단한 설명 및 사용방법 정리 file 황제낙엽 2017.07.10 135
238 Generate random numbers (Random.java) 황제낙엽 2017.07.02 490
237 쓰레드(Thread)를 중간에 종료시키는 방법 황제낙엽 2017.03.15 5127
236 JSON 라이브러리(API) 종류 황제낙엽 2017.01.18 404
235 [JSON기초04] 자바 JSON 데이터에서 KEY 값 알아오기 (TIP) 황제낙엽 2017.01.18 6641
234 [JSON기초03] 자바 JSON Google Simple JSON을 이용한 간단한 JSON DATA 파싱 황제낙엽 2017.01.18 566
233 [JSON기초02] 자바 JSON Google Simple JSON을 이용한 간단한 JSON DATA 생성 황제낙엽 2017.01.18 111
232 [JSON기초01] JSON이란? XML이란? JSON 개념, XML 개념 설명 황제낙엽 2017.01.18 408