다음을 통해 공유


방법: 개발 중 사용할 임시 인증서 만들기

WCF(Windows Communication Foundation)를 사용하여 보안 서비스 또는 클라이언트를 개발할 때 자격 증명으로 사용할 X.509 인증서를 제공해야 하는 경우가 많습니다. 일반적으로 인증서는 루트 인증 기관이 컴퓨터의 신뢰할 수 있는 루트 인증 기관 저장소에 있는 인증서 체인의 일부입니다. 인증서 체인을 사용하면 일반적으로 루트 인증 기관이 조직 또는 비즈니스 사업부에 있는 인증서 집합의 범위를 지정할 수 있습니다. 개발 시 이를 에뮬레이트하려면 보안 요구 사항에 맞는 두 개의 인증서를 만듭니다. 첫 번째 인증서는 신뢰할 수 있는 루트 인증 기관 저장소에 있는 자체 서명된 인증서이고, 두 번째 인증서는 첫 번째 인증서에서 만들어지고 로컬 컴퓨터 위치의 개인 저장소나 현재 사용자 위치의 개인 저장소에 있습니다. 이 항목에서는 PowerShell New-SelfSignedCertificate) cmdlet을 사용하여 이러한 두 인증서를 만드는 단계를 안내합니다.

Important

New-SelfSignedCertificate cmdlet이 생성하는 인증서는 테스트용으로만 제공됩니다. 서비스 또는 클라이언트를 배포할 때는 인증 기관에서 제공하는 적절한 인증서를 사용해야 합니다. 조직 또는 타사의 Windows Server 인증서 서버에서 가져올 수 있습니다.

기본적으로 New-SelfSignedCertificate cmdlet은 자체 서명된 인증서를 만들며 이러한 인증서는 안전하지 않습니다. 자체 서명된 인증서를 신뢰할 수 있는 루트 인증 기관 저장소에 배치하면 배포 환경을 보다 가깝게 시뮬레이션하는 개발 환경을 만들 수 있습니다.

인증서 만들기 및 사용에 대한 자세한 내용은 인증서 작업을 참조하세요. 인증서를 자격 증명으로 사용하는 방법에 대한 자세한 내용은 서비스 및 클라이언트 보안을 참조하세요. Microsoft Authenticode 기술을 사용하는 방법에 대한 자습서는 Authenticode Overviews and Tutorials를 참조하십시오.

자체 서명된 루트 인증 기관 인증서를 만들고 프라이빗 키를 내보내려면

다음 명령은 현재 사용자 개인 저장소에 주체 이름이 "RootCA"인 자체 서명된 인증서를 만듭니다.

$rootCert = New-SelfSignedCertificate -CertStoreLocation Cert:\CurrentUser\My -DnsName "RootCA" -TextExtension @("2.5.29.19={text}CA=true") -KeyUsage CertSign,CrlSign,DigitalSignature

이후 단계에서 필요한 위치로 가져올 수 있도록 인증서를 PFX 파일로 내보내야 합니다. 프라이빗 키로 인증서를 내보낼 때 이를 보호하기 위해 암호가 필요합니다. 암호를 SecureString에 저장하고 Export-PfxCertificate cmdlet을 사용하여 연결된 프라이빗 키가 있는 인증서를 PFX 파일로 내보냅니다. 또한 Export-Certificate cmdlet을 사용하여 공용 인증서만 CRT 파일에 저장합니다.

[System.Security.SecureString]$rootCertPassword = ConvertTo-SecureString -String "password" -Force -AsPlainText
[String]$rootCertPath = Join-Path -Path 'cert:\CurrentUser\My\' -ChildPath "$($rootCert.Thumbprint)"
Export-PfxCertificate -Cert $rootCertPath -FilePath 'RootCA.pfx' -Password $rootCertPassword
Export-Certificate -Cert $rootCertPath -FilePath 'RootCA.crt'

루트 인증 기관 인증서로 서명된 새 인증서를 만들려면

다음 명령은 발급자의 프라이빗 키를 사용하여 주체 이름이 "SignedByRootCA"인 RootCA에서 서명한 인증서를 만듭니다.

$testCert = New-SelfSignedCertificate -CertStoreLocation Cert:\LocalMachine\My -DnsName "SignedByRootCA" -KeyExportPolicy Exportable -KeyLength 2048 -KeyUsage DigitalSignature,KeyEncipherment -Signer $rootCert

마찬가지로 프라이빗 키가 있는 서명된 인증서를 PFX 파일에 저장하고 공개 키만 CRT 파일에 저장합니다.

[String]$testCertPath = Join-Path -Path 'cert:\LocalMachine\My\' -ChildPath "$($testCert.Thumbprint)"
Export-PfxCertificate -Cert $testCertPath -FilePath testcert.pfx -Password $rootCertPassword
Export-Certificate -Cert $testCertPath -FilePath testcert.crt

신뢰할 수 있는 루트 인증 기관 저장소에 인증서 설치

자체 서명된 인증서를 만들면 신뢰할 수 있는 루트 인증 기관 저장소에 설치할 수 있습니다. 이때 인증서로 서명된 모든 인증서는 컴퓨터에 의해 신뢰됩니다. 따라서 인증서가 더 이상 필요하지 않으면 즉시 저장소에서 삭제합니다. 이 루트 인증 기관 인증서를 삭제하면 해당 인증서로 서명된 다른 모든 인증서의 권한이 해제됩니다. 루트 인증 기관 인증서는 단순히 필요에 따라 인증서 그룹의 범위를 지정할 수 있는 메커니즘입니다. 예를 들어 피어 투 피어 애플리케이션에서는 일반적으로 제공된 인증서로 개인의 ID를 신뢰하므로 루트 인증 기관이 필요하지 않습니다.

신뢰할 수 있는 루트 인증 기관에 자체 서명된 인증서를 설치하려면

  1. 인증서 스냅인을 엽니다. 자세한 내용은 방법: MMC 스냅인을 사용하여 인증서 보기를 참조하세요.

  2. 인증서를 저장할 폴더( 로컬 컴퓨터 또는 현재 사용자)를 엽니다.

  3. 신뢰할 수 있는 루트 인증 기관 폴더를 엽니다.

  4. 인증서 폴더를 마우스 오른쪽 단추로 클릭하고 모든 작업을 클릭한 다음 가져오기를 클릭합니다.

  5. 화면의 마법사 지침에 따라 RootCA.pfx를 저장소로 가져옵니다.

WCF에서 인증서 사용

임시 인증서를 설정했으면 클라이언트 자격 증명 형식으로 인증서를 지정하는 WCF 솔루션을 이 인증서를 사용하여 개발할 수 있습니다. 예를 들어 다음 XML 구성에서는 메시지 보안과 인증서를 클라이언트 자격 증명 형식으로 지정합니다.

인증서를 클라이언트 자격 증명 형식으로 지정하려면

  1. 서비스의 구성 파일에서 다음 XML을 사용하여 보안 모드를 메시지로 설정하고 클라이언트 자격 증명 형식을 인증서로 설정합니다.

    <bindings>
      <wsHttpBinding>
        <binding name="CertificateForClient">
          <security>
            <message clientCredentialType="Certificate" />
          </security>
        </binding>
      </wsHttpBinding>
    </bindings>
    
  2. 클라이언트의 구성 파일에서 다음 XML을 사용하여 인증서가 사용자 저장소에 있고 SubjectName 필드에서 "CohoWinery" 값 검색을 통해 인증서를 찾을 수 있도록 지정합니다.

    <behaviors>
      <endpointBehaviors>
        <behavior name="CertForClient">
          <clientCredentials>
            <clientCertificate findValue="CohoWinery" x509FindType="FindBySubjectName" />
          </clientCredentials>
        </behavior>
      </endpointBehaviors>
    </behaviors>
    

WCF에서의 인증서 사용에 대한 자세한 내용은 Working with Certificates을 참조하세요.

.NET Framework 보안

인증서를 마우스 오른쪽 단추로 클릭한 다음 삭제 를 클릭하여 신뢰할 수 있는 루트 인증 기관개인폴더에서 임시 루트 인증 기관 인증서를 모두 삭제합니다.

참고 항목