Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
[mytest.zip]    
(연관된 글이 11개 있습니다.)
인증서 관련(CER, PVK, SPC, PFX) 파일 만드는 방법


그다지 어렵지 않습니다. ^^

How to create a self-signed certificate that can be used to sign MS-Office VBA projects (Excel/Word macros) on multiple computers
; http://www.source-code.biz/snippets/vbasic/3.htm

위의 글에서 잘 설명해 주고 있는데요.

일단, Visual Studio 2010이 정상적으로 설치되어 있다면 다음과 같은 2개의 명령어는 아무 문제없이 실행됩니다.

makecert -n "CN=myserver" -r -sv mycert.pvk mycert.cer
cert2spc mycert.cer mycert.spc

그렇다면, pvk, cer, spc 파일은 얻어냈군요. 참고로, WCF 서비스 용으로 인증서를 만든다면 다음과 같이 Key Exchange 옵션을 주어야 합니다.

makecert -n "CN=myserver" -r -sky exchange -sv mycert.pvk mycert.cer

CN 이름은 보통 HTTPS URL의 도메인 이름을 주게 됩니다. 예를 들어 "https://myserver/test.aspx"라고 접근하고 싶은 경우에는 반드시 "CN=myserver"라고 주어야 합니다. (그렇지 않으면 웹 브라우저에서 인증서 경고가 나오게 됩니다.)

자,,, 이제 마지막으로 PFX 파일을 만들어야 하는데요.
다음의 경로에서 PVKIMPRT.exe를 다운로드 받습니다.

Office 2000 Tool: PVK Digital Certificate Files Importer
; http://www.microsoft.com/downloads/details.aspx?FamilyID=F9992C94-B129-46BC-B240-414BDFF679A7&displaylang=EN

참고로, 저 같은 경우 Windows 7 64비트에서 위의 프로그램을 설치했더니 비정상 종료가 되어서 "Windows XP 모드"에서 설치를 한 후 pvkimprt.exe를 빼왔습니다.

그래서 다음과 같이 실행하면 pfx 파일을 얻을 수 있습니다.

pvkimprt -pfx mycert.spc mycert.pvk

중간에 개인키에 대한 암호를 묻는데 잘 기억해 두셔야 합니다. 나중에 "인증서 관리자"를 통해서 인증서 보관소에 넣을 때 물어보기 때문입니다.

pfx 파일을 인증서 보관소에 설치하는 방법에 대해서는 다음의 글을 참고합니다.

5.1 인증서 관리 - 내보내기/가져오기
  [가져오기 - PFX 인증서 파일을 대상 컴퓨터에 설치]
; https://www.sysnet.pe.kr/2/0/392

참고로, 보통 WCF나 웹 애플리케이션처럼 다른 사용자 계정(보통 NetworkService)으로 실행되는 응용 프로그램을 위한 인증서를 등록할 때는 "Current User" 영역 보다는 "Local Computer" 영역에 설치해야 합니다. 이를 위해서는 보통 "인증서 관리자"를 이용하게 되는데 자세한 방법은 다음의 글에서 참고합니다.

5.3 인증서 관리 - 인증서 MMC 관리자
; https://www.sysnet.pe.kr/2/0/395

아니... 이참에 윈도우즈의 "인증서 관리"를 제대로 이해하고 싶다면 다음의 글을 통째로 읽어보실 것을 권합니다. ^^

윈도우즈 인증서 서비스 이야기
; https://www.sysnet.pe.kr/2/0/353



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

[연관 글]






[최초 등록일: ]
[최종 수정일: 7/8/2021]

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

비밀번호

댓글 작성자
 



2010-08-04 01시06분
첨부된 파일은 "CN=mytest", 비밀번호 "0000"으로 만들어진 .spc, .cer, .pfx, .pvk 파일입니다.
kevin25

... 16  [17]  18  19  20  21  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13223정성태1/20/20234734오류 유형: 838. RDP 연결 오류 - The two computers couldn't connect in the amount of time allotted
13222정성태1/20/20234409개발 환경 구성: 657. WSL - DockerDesktop.vhdx 파일 위치를 옮기는 방법
13221정성태1/19/20234592Linux: 57. C# - 리눅스 프로세스 메모리 정보파일 다운로드1
13220정성태1/19/20234677오류 유형: 837. NETSDK1045 The current .NET SDK does not support targeting .NET ...
13219정성태1/18/20234288Windows: 220. 네트워크의 인터넷 접속 가능 여부에 대한 판단 기준
13218정성태1/17/20234194VS.NET IDE: 178. Visual Studio 17.5 (Preview 2) - 포트 터널링을 이용한 웹 응용 프로그램의 외부 접근 허용
13217정성태1/13/20234800디버깅 기술: 185. windbg - 64비트 운영체제에서 작업 관리자로 뜬 32비트 프로세스의 덤프를 sos로 디버깅하는 방법
13216정성태1/12/20235034디버깅 기술: 184. windbg - 32비트 프로세스의 메모리 덤프인 경우 !peb 명령어로 나타나지 않는 환경 변수
13215정성태1/11/20236765Linux: 56. 리눅스 - /proc/pid/stat 정보를 이용해 프로세스의 CPU 사용량 구하는 방법 [1]
13214정성태1/10/20236123.NET Framework: 2087. .NET 6부터 SourceGenerator와 통합된 System.Text.Json [1]파일 다운로드1
13213정성태1/9/20235594오류 유형: 836. docker 이미지 빌드 시 "RUN apt install ..." 명령어가 실패하는 이유
13212정성태1/8/20235486기타: 85. 단정도/배정도 부동 소수점의 정밀도(Precision)에 따른 형변환 손실
13211정성태1/6/20235428웹: 42. (https가 아닌) http 다운로드를 막는 웹 브라우저
13210정성태1/5/20234577Windows: 219. 윈도우 x64의 경우 0x00000000`7ffe0000 아래의 주소는 왜 사용하지 않을까요?
13209정성태1/4/20234472Windows: 218. 왜 윈도우에서 가상 메모리 공간은 64KB 정렬이 된 걸까요?
13208정성태1/3/20234433.NET Framework: 2086. C# - Windows 운영체제의 2MB Large 페이지 크기 할당 방법파일 다운로드1
13207정성태12/26/20224716.NET Framework: 2085. C# - gpedit.msc의 "User Rights Assignment" 특권을 코드로 설정/해제하는 방법파일 다운로드1
13206정성태12/24/20224970.NET Framework: 2084. C# - GetTokenInformation으로 사용자 SID(Security identifiers) 구하는 방법 [3]파일 다운로드1
13205정성태12/24/20225220.NET Framework: 2083. C# - C++과의 연동을 위한 구조체의 fixed 배열 필드 사용 (2)파일 다운로드1
13204정성태12/22/20224653.NET Framework: 2082. C# - (LSA_UNICODE_STRING 예제로) CustomMarshaler 사용법파일 다운로드1
13203정성태12/22/20224807.NET Framework: 2081. C# Interop 예제 - (LSA_UNICODE_STRING 예제로) 구조체를 C++에 전달하는 방법파일 다운로드1
13202정성태12/21/20225176기타: 84. 직렬화로 설명하는 Little/Big Endian파일 다운로드1
13201정성태12/20/20225734오류 유형: 835. PyCharm 사용 시 C 드라이브 용량 부족
13200정성태12/19/20224669오류 유형: 834. 이벤트 로그 - SSL Certificate Settings created by an admin process for endpoint
13199정성태12/19/20224857개발 환경 구성: 656. Internal Network 유형의 스위치로 공유한 Hyper-V의 VM과 호스트가 통신이 안 되는 경우
13198정성태12/18/20224806.NET Framework: 2080. C# - Microsoft.XmlSerializer.Generator 처리 없이 XmlSerializer 생성자를 예외 없이 사용하고 싶다면?파일 다운로드1
... 16  [17]  18  19  20  21  22  23  24  25  26  27  28  29  30  ...