Microsoft MVP성태의 닷넷 이야기
[답변]: 윈도우즈 인증서 관련해서 문의를 드립니다. [링크 복사], [링크+제목 복사],
조회: 19372
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
부모글 보이기/감추기

우선, 상황을 정리해 볼까요?

한국 -> 미국 HTTPS (PHP)

이렇게 접근을 하고 있는데, 현재 미국 측 서버에서 다음과 같은 오류를 내고 있는 것이죠? ^^

A certificate is required to complete client authentication

원인은, "클라이언트 측 신분을 증명하는 인증서"를 서버에 제출하지 않았기 때문입니다.

이에 대해서 잠시 설명해 보면, 보통 HTTPS 서버는 다음과 같은 동작을 합니다.

접속 전: 미국 HTTPS (개인키, 공개키 인증서 CER 소유)
접속: 한국 -> 미국 HTTPS
      미국 HTTPS 서비스에서 한국 측으로 공개키 인증서 CER 을 내려주고,

이후 통신: 한국 -> (미국측의 CER 공개키를 이용하여 암호화) -> 미국 HTTPS 서버에서는 개인키로 복호화

위의 통신 과정은 지극히 정상입니다. pfx 파일은 미국측이 가지고 있어야 할 파일이지, 한국 측에 내려가서는 안됩니다. 한국 측에서는 공개키만 포함한 CER 만 있으면 되기 때문에 "You have a private key that corresponds to this certificate" 문구가 없는 것입니다.

그런데, 문제는? 미국 측의 HTTPS 설정이 한국 측, 즉 "클라이언트 측"의 인증서를 요구하고 있다는 점입니다. "A certificate is required to complete client authentication" 메시지가 바로 그것입니다.

즉, 이 문제를 해결하기 위해서는 오히려 한국 측에서 Verisign 등의 기관을 통해서 인증서를 받아야 하고, pfx 는 한국 서버에 설치하고 미국 측의 HTTPS 서비스를 호출하는 코드에 CER 인증서를 지정해 주어야 합니다. IIS 를 예로 들자면 다음과 같은 상황입니다.

Using Client Certificate Authentication with IIS 6.0 Web Sites
 - Configure the Web Site to Require a Client Certificate and use Basic Authentication
; http://www.windowsecurity.com/articles/Client-Certificate-Authentication-IIS6.html

IIS 7에서 클라이언트 측 인증서 사용시 주의점 
; https://www.sysnet.pe.kr/2/0/418

만약, 이것이 미국 측 HTTPS 서비스가 원하는 상황이 아니라면, 그냥 미국 측에서 (IIS 의 옵션에 비교하자면 "Require client certificates") 옵션을 꺼버리면 됩니다. 옵션을 끄는 방법은 PHP를 호스팅하는 WAS에 따라 다르겠고.

그럼, 이제 한국 측 서버에서 서비스를 받는 고객 측으로 넘어가 볼까요? 만약, 고객의 웹 브라우저가 한국 측 서버와만 통신을 하게 된다면 이런 경우 인증서 상으로 고객에게 요구되는 것은 없습니다. 그런데, 고객의 웹 브라우저에 내려가는 링크 중에서 미국 측 HTTPS 서비스를 직접 접속하게 되는 것이 있다면 고객도 동일하게 Verisign으로부터 인증서를 받아야 합니다. (이건 사실 말도 안되는 상황이죠.)

따라서, 정상적인 서비스를 위해서는 절대로 고객의 웹 브라우저에서 미국 측 HTTPS 서비스를 직접 연결하도록 해서는 안됩니다. 필요한 내용이 있다면, 전부 한국 측 HTTP 서버에서 중계를 해주어야 합니다.

마지막으로, 만기일에 대한 걱정인데요. 그 부분은 걱정하지 않으셔도 됩니다. 상호 간에 서비스가 계속되는 한 인증기관으로부터 연장을 받을 것이기 때문에 그런 부분은 자동으로 처리됩니다. 아마도 미국 측 HTTPS 서비스 담당자는 이에 익숙해져 있을 테니 상관없지만, 오히려 한국 측 HTTP 서버 담당자가 인증서 갱신을 잊어버릴 수도 있습니다. 만약 그렇게 되면, 만기일이 지나면서는 미국 측 HTTPS 서버에서 오류를 내뱉으며 서비스 제공을 하지 않을 것입니다.







[최초 등록일: ]
[최종 수정일: 10/11/2010]


비밀번호

댓글 작성자
 




... 16  17  18  [19]  20  21  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
5487진우4/27/202113349C# 엑셀 자동화 성능 향상 문의 [2]
5486지나가던...4/26/202113140닷넷 구현 코드 관련 질문 [2]
5485이재원4/17/202113316교재 315페이지 내용 질문 [3]
5484Syong4/16/202117266윈폼 기반의 응용프로그램 dll 참조와 32,64bit 빌드 관련 문의 [4]
5483한예지 donator4/15/202112293익명 형식과 var 관계 질문 있습니다. [2]
5482질문4/13/202114260WPF를 위한 MVVM toolkit 선택과 관련한 문의드립니다. [4]
5480한예지 donator4/5/202115138GetHashCode 질문있습니다! [2]
5479한예지 donator4/4/202114029Equals를 닷넷에서 어떻게 구현했는지 보고 싶을 떄는 어떻게 해야 될까요? [2]
5478갑자기C#3/23/202116997C# Winform에서 TextBox없이 입력 받을 수 있나요? [7]
5477달팽이3/18/202113156c# 도형을 그린후 편집하는 방법이 궁금합니다. [2]파일 다운로드1
5475dimo...3/2/202114058POH가 .NET 5에 추가된 것으로 알고 있습니다. POH가 유용한 경우는 어떤 경우가 있을까요? [1]
5474Syong2/26/202113597사용자 지정 컨트롤 생성시 Invalidate, Update, Refresh의 차이점 [2]
5473한예지 donator2/25/202113025디자인 타임이 뭔지 궁금합니다!! [5]
5472dimo...2/24/202114461등록하지 않고 ocx를 사용하는 `키움`관련 포스팅을 따라가다 질문드립니다. [9]
5471남산2/21/202112933MarshalDirectiveException 에 대한 질문입니다. [1]
5470한예지 donator2/7/202112655yield 질문있습니다!! [2]
5469유호성2/6/202112523Parallel + Task.Run 동시 실행 환경에서 간헐적으로 Task.Run()에서 null이 리턴됩니다. [3]파일 다운로드1
5467hero...2/4/202113078실행 환경에 따른 Thread.Sleep 딜레이 차이 질문 [8]
5466pr1/29/202112937c# winform load시 작업표시줄에 뜨지 않는 현상을 겪으신적이 있으신가요? [4]파일 다운로드1
5465영귤1/28/202113097두 번째 await 부터는 스레드 개수만 늘어나는 것이 아닌가요 [1]
5464민우1/26/202113911C# 빌드시 코드 치환되는걸 확인하는 방법 문의 [2]
5463한예지 donator1/24/202114646Parameters.AddWithValue 와 Parameters.Add 의 차이점이 궁금합니다. [2]
5462C#초보1/22/202114781사용자 정의 메시지 전달이 가능한가요? [2]
5461한예지 donator1/22/202113827AsEnumerable() 메서드 질문 있습니다! [2]
5459한예지 donator1/21/202113102typeof와 GetType의 차이점 질문있습니다. [2]
5458진우1/20/202114314C# DataTable 에 SQL 쿼리문을 실행하는 방법 문의 (LINQ 사용하지 않고) [6]
... 16  17  18  [19]  20  21  22  23  24  25  26  27  28  29  30  ...