우선 @devstuff에서 설명한 솔루션을 사용했기 때문에 사과드립니다. 그러나 나는 그것을 개선 할 몇 가지 방법을 찾았습니다.
- 자체 서명 된 인증서 처리 추가
- 인증서의 원시 데이터로 비교
- 실제 인증 기관 유효성 검사
- 몇 가지 추가 의견 및 개선
내 수정은 다음과 같습니다.
private static X509Certificate2 caCertificate2 = null;
private static bool ValidateServerCertficate(
object sender,
X509Certificate cert,
X509Chain chain,
SslPolicyErrors sslPolicyErrors)
{
if (sslPolicyErrors == SslPolicyErrors.None)
{
return true;
}
chain.ChainPolicy.VerificationFlags = X509VerificationFlags.AllowUnknownCertificateAuthority;
var returnedServerCert2 = new X509Certificate2(cert);
chain.ChainPolicy.ExtraStore.Add(caCertificate2);
bool isChainValid = chain.Build(returnedServerCert2);
if (!isChainValid)
{
string[] errors = chain.ChainStatus
.Select(x => String.Format("{0} ({1})", x.StatusInformation.Trim(), x.Status))
.ToArray();
string certificateErrorsString = "Unknown errors.";
if (errors != null && errors.Length > 0)
{
certificateErrorsString = String.Join(", ", errors);
}
Log.Error("Trust chain did not complete to the known authority anchor. Errors: " + certificateErrorsString);
return false;
}
bool isValid = chain.ChainElements
.Cast<X509ChainElement>()
.Any(x => x.Certificate.RawData.SequenceEqual(caCertificate2.GetRawCertData()));
if (!isValid)
{
Log.Error("Trust chain did not complete to the known authority anchor. Thumbprints did not match.");
}
return isValid;
}
인증서 설정 :
caCertificate2 = new X509Certificate2("auth/ca.crt", "");
var clientCertificate2 = new X509Certificate2("auth/client.pfx", "");
델리게이트 메서드 전달
ServerCertificateValidationCallback(ValidateServerCertficate)
client.pfx
다음과 같이 KEY 및 CERT로 생성됩니다.
openssl pkcs12 -export -in client.crt -inkey client.key -out client.pfx