Microsoft MVP성태의 닷넷 이야기
Windows: 5. Vista 와 웹 인증 등록 서비스의 문제 [링크 복사], [링크+제목 복사],
조회: 27586
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

현재 Vista에서는 Windows 2003의 "인증서 서비스"의 웹 등록 애플리케이션을 사용할 수가 없습니다. 이미 해보신 분들은 아시겠지만, 아래 화면과 같이 "ActiveX 컨트롤 다운로드 중..." 이라는 메시지만 한없이 기다리게 되는데요.

cert_service_and_vista_1.png

이에 대해 다음과 같은 KB 자료가 11월 27일 자료로 올라와 있습니다.

How to use Certificate Services Web enrollment pages together with Windows Vista
; http://support.microsoft.com/kb/922706/en-us

여기서 잠시 풀이해 보면.

certsrv 웹 애플리케이션에서 제공되는 asp 페이지들은, 클라이언트와의 상호 작용을 대부분 Xenroll이라는 ActiveX 컨트롤을 통해서 하는데, Vista에서는 Xenroll 컨트롤이 설치되어 있지 않기 때문에(Xenroll은 구시대의 유물이기 되어 버렸기 때문에 Vista에는 없어졌음: deprecated) 발생하는 문제라고 합니다.

대신에 Vista에서는 "CertEnroll" COM 개체로 제공이 되어지며, Xenroll은 시스템상에서 막아두었기 때문에 수동으로 직접 등록한다고 해도 실패하게 됩니다.

현재는, 이렇게 "CertEnroll" 컴포넌트와 동작하는 certsrv 웹 애플리케이션은 "Longhorn" 서버에만 구현되어져 있습니다. (Longhorn 서버에 구현된 certsrv 웹 애플리케이션은 기존 "Xenroll"과도 잘 동작한다고 합니다.) 참고로, 위의 문서에서는 Longhorn 베타 3을 언급하고 있지만, MSDN 구독자 다운로드 센터를 통해서 현재(2006-12-06) 공개되어 있는 빌드 5600의 certsrv 웹 애플리케이션도 정상적으로 동작하고 있습니다.

어쨌든, 개선된 CertEnroll로 인해, 서버 측의 asp 페이지를 통해서 동작하던 기능들이 필요없어졌기 때문에 그에 맞춰 제거되었다고 합니다.

현재의 서버 운영체제 버전으로 정리해 보면 다음과 같습니다. (아마도, Windows 2003 SP2의 정식 버전에서는 정상적으로 지원하지 않을까 예상해 봅니다.)

  Windows Server 2003 and Windows Server 2003 SP1 Windows Server 2003 SP2 Windows Server "Longhorn"
Client computers that are earlier than Windows Vista 지원 지원 지원
Windows Vista-based client computers 미지원 미지원 지원

Vista에 대한 certsrv 웹 애플리케이션에 대한 정상적인 서비스를 제공하기 위해서 위의 토픽에서는 현재 베타로 공개된 롱혼 서버로부터 변경된 웹 애플리케이션 소스를 가져올 것을 권하고 있습니다.

근데, 좀 ^^; 무책임한 것 같습니다. 이를 위해서 여러분들은 MSDN 구독자 다운로드 센터로부터 "Longhorn 빌드 5600"을 다운로드해야 합니다. 다운로드 후에 다음 화면과 같이 "서버 역할 구성 마법사"를 이용해서 "Active Directory Certificate Server"를 선택해서 별도로 설치를 해야 합니다.

cert_service_and_vista_2.png

주의해야 할 것은, 인증서 서비스만 설치하시면 안 되고 다음과 같이 "Certificate Authority Web Enrollment"까지 선택해서 설치를 해주셔야 certsrv에 해당하는 웹 애플리케이션이 (아마도) 설치될 것입니다.

cert_service_and_vista_3.png

자, 이렇게 롱혼 서버를 구성하셨으면, 다음과 같은 절차를 통해서 여러분들의 Windows 2003 서버를 업데이트시켜 주시면 Windows Vista에서도 certsrv 웹 애플리케이션을 정상적으로 사용할 수 있게 됩니다.

1. %systemroot%\System32\Certsrv 폴더에서 "Certdat.inc", "Certenroll" 폴더를 제외한 모든 파일/폴더를 삭제합니다.

* 위의 폴더 중에서 "CertControl" 폴더를 삭제하기 위해서는 "Safe mode"로 부팅해야 합니다.

2. "Longhorn" 서버에서 "Certdat.inc" 파일을 제외하고, "CertSrv\EN-US" 폴더의 모든 내용을 Windows 2003의 "%systemroot%\System32\certsrv 폴더에 복사합니다. (Certdat.inc 파일이 같은 폴더에 없기 때문에, 일부러만 덮어쓰지 않으면 됩니다.)

3. Windows 2003의 Certdat.inc 파일을 편집해야 합니다. 우선, 다음과 같은 내용을 찾아서 삭제합니다.

' control versions
sXEnrollVersion="5,131,3686,0"
sScrdEnrlVersion="5,131,3790,1206"
sScrdW2KVersion="5,131,2195,5583"

4. Certsrv 폴더에 있는 모든*.asp 파일을 열어서,

<!-- #include FILE="..\certdat.inc"-->

위의 내용을 아래와 같이 수정해 줍니다.

<!-- #include FILE="certdat.inc"-->

5. Certsgcl.inc 파일을 열어서, WriteTemplateList 함수와 IsUserTemplateAvailable 함수 내부의 다음과 같은 ActiveX 컨트롤 ProgID를 수정해 줍니다.

Set WebEnrlServer=Server.CreateObject("WebEnrlServer.WebEnrlServer.1")
==> Set WebEnrlServer=Server.CreateObject("SCrdEnr.SCrdEnr.1")

6. 마지막으로, Vista 및 Longhorn 기반의 클라이언트 컴퓨터가 인증서 발급 웹 사이트를 이용하기 위해서는 반드시 HTTPS로 접속해야 합니다. 이를 위해, 아예 IIS 서버에서 해당 웹 애플리케이션을 기본적으로 "HTTPS required"로 설정합니다.



그래서, ^^ 현재 제 sysnet 웹 사이트는 롱혼 서버에서 제공되는 웹 애플리케이션을 적용하여 비스타에서도 동작되어지도록 구성된 상태입니다.



[이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/20/2023]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2008-07-14 09시33분
[정엽] 자료가 정리가 잘되어 퍼갑니다. ^^

출저는 명시하겠습니다. ^^
[guest]
2010-02-09 08시31분
[김성호] 좋은 자료 감사합니다. 그런데 한 가지 궁금한게 있습니다. 마지막에 " IIS 서버에서 해당 웹 애플리케이션을 기본적으로 "HTTPS required" 로 설정합니다." 이 부분은 IIS에서 설정을 어떻게 하는 건가요?
IIS를 아무리 뒤져봐도 "HTTPS required"라는 옵션은 없던대요..^^;
[guest]
2010-02-09 08시54분
IIS 7이상의 경우, "Sites" / "Default Web Site" 노드를 클릭하고 오른쪽 패널의 "IIS" 범주에 "SSL Settings"를 선택하면 "Require SSL" 설정화면이 나옵니다.
kevin25
2010-02-10 09시20분
[김성호] 답변 감사드립니다.^^ 염치불구하고 하나 더 질문 드리자면...현재 제가 사용하고 있는 IIS 버전이 6.0 입니다. ^^; 6.0에서는 해당 옵션이 어디에 있나요?
위에 내용들을 적용하기 위해서는 IIS 7.0을 사용해야하나요?
[guest]
2010-02-13 09시58분
해당 웹 사이트의 등록정보 화면에서 "Directory Security" 탭의 "Secure communications" 범주에 "Edit..."버튼을 누르면 "Require secure channel(SSL)"설정을 할 수 있습니다. ^^
kevin25

... 16  17  18  19  20  21  22  23  24  25  26  27  28  [29]  30  ...
NoWriterDateCnt.TitleFile(s)
12922정성태1/14/20227081개발 환경 구성: 625. AKS - Azure Kubernetes Service 생성 및 SLO/SLA 변경 방법
12921정성태1/14/20226003개발 환경 구성: 624. Docker Desktop에서 별도 서버에 설치한 docker registry에 이미지 올리는 방법
12920정성태1/14/20226773오류 유형: 786. Camtasia - An error occurred with the camera: Failed to Add Video Sampler.
12919정성태1/13/20226611Windows: 199. Host Network Service (HNS)에 의해서 점유되는 포트
12918정성태1/13/20226820Linux: 47. WSL - shell script에서 설정한 환경 변수가 스크립트 실행 후 반영되지 않는 문제
12917정성태1/12/20225986오류 유형: 785. C# - The type or namespace name '...' could not be found (are you missing a using directive or an assembly reference?)
12916정성태1/12/20225792오류 유형: 784. TFS - One or more source control bindings for this solution are not valid and are listed below.
12915정성태1/11/20226054오류 유형: 783. Visual Studio - We didn't find any interpreters
12914정성태1/11/20228078VS.NET IDE: 172. 비주얼 스튜디오 2022의 파이선 개발 환경 지원
12913정성태1/11/20228570.NET Framework: 1133. C# - byte * (바이트 포인터)를 FileStream으로 쓰는 방법 [1]
12912정성태1/11/20229257개발 환경 구성: 623. ffmpeg.exe를 사용해 비디오 파일의 이미지를 PGM(Portable Gray Map) 파일 포맷으로 출력하는 방법 [1]
12911정성태1/11/20226450VS.NET IDE: 171. 비주얼 스튜디오 - 더 이상 만들 수 없는 "ASP.NET Core 3.1 Web Application (.NET Framework)" 프로젝트
12910정성태1/10/20226964제니퍼 .NET: 30. 제니퍼 닷넷 적용 사례 (8) - CPU high와 DB 쿼리 성능에 문제가 함께 있는 사이트
12909정성태1/10/20228331오류 유형: 782. Visual Studio 2022 설치 시 "Couldn't install Microsoft.VisualCpp.Redist.14.Latest"
12908정성태1/10/20226135.NET Framework: 1132. C# - ref/out 매개변수의 IL 코드 처리
12907정성태1/9/20226687오류 유형: 781. (youtube-dl.exe) 실행 시 "This app can't run on your PC" / "Access is denied." 오류 발생
12906정성태1/9/20227328.NET Framework: 1131. C# - 네임스페이스까지 동일한 타입을 2개의 DLL에서 제공하는 경우 충돌을 우회하는 방법 [1]파일 다운로드1
12905정성태1/8/20226982오류 유형: 780. Could not load file or assembly 'Microsoft.VisualStudio.TextTemplating.VSHost.15.0, Version=16.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a' or one of its dependencies.
12904정성태1/8/20228980개발 환경 구성: 623. Visual Studio 2022 빌드 환경을 위한 github Actions 설정 [1]
12903정성태1/7/20227585.NET Framework: 1130. C# - ELEMENT_TYPE_INTERNAL 유형의 사용 예
12902정성태1/7/20227628오류 유형: 779. SQL 서버 로그인 에러 - provider: Shared Memory Provider, error: 0 - No process is on the other end of the pipe.
12901정성태1/5/20227659오류 유형: 778. C# - .NET 5+에서 warning CA1416: This call site is reachable on all platforms. '...' is only supported on: 'windows' 경고 발생
12900정성태1/5/20229335개발 환경 구성: 622. vcpkg로 ffmpeg를 빌드하는 경우 생성될 구성 요소 제어하는 방법
12899정성태1/3/20228834개발 환경 구성: 621. windbg에서 python 스크립트 실행하는 방법 - pykd (2)
12898정성태1/2/20229426.NET Framework: 1129. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 비디오 인코딩 예제(encode_video.c) [1]파일 다운로드1
12897정성태1/2/20228245.NET Framework: 1128. C# - 화면 캡처한 이미지를 ffmpeg(FFmpeg.AutoGen)로 동영상 처리 [4]파일 다운로드1
... 16  17  18  19  20  21  22  23  24  25  26  27  28  [29]  30  ...