كيفية إيقاف إبطال شهادة لعميل خدمة WCF؟
-
03-07-2019 - |
سؤال
وكيف يمكنني إيقاف إبطال شهادة لعميل خدمة WCF؟ تم إنشاء وكيل العميل wsdl.exe ويرث SoapHttpClientProtocol.
المحلول
وأعتقد كنت تبحث عن ServicePointManager.ServerCertificateValidationCallback
:
والذي يأخذ المندوب RemoteCertificateValidationCallback
:
ولقد تعاملت أبدا مع شهادة تم إبطالها من قبل (لدي اليد للتعامل مع قضايا أخرى مثل منتهية الصلاحية في SSL)، ولكن انا التخمين كنت تفعل شيئا مثل:
class Program
{
static void Main(string[] args)
{
ServicePointManager.ServerCertificateValidationCallback +=
new RemoteCertificateValidationCallback(ValidateCertificate);
// Do WCF calls...
}
public static bool ValidateCertificate(object sender, X509Certificate cert,
X509Chain chain, SslPolicyErrors sslPolicyErrors)
{
if(sslPolicyErrors == SslPolicyErrors.RemoteCertificateChainErrors)
{
foreach(X509ChainStatus chainStatus in chain.ChainStatus)
{
if(chainStatus.Status == X509ChainStatusFlags.Revoked)
{
return true;
}
}
}
return false;
}
}
نصائح أخرى
ويمكنك تعيين التحقق من صحة وإلغاء خيارات شهادة في ملف التكوين للتطبيق الخاص بك:
لا تنتمي إلى StackOverflow