c# – 如何忽略SSL证书是由未知的证书颁发机构问题签名的?

前端之家收集整理的这篇文章主要介绍了c# – 如何忽略SSL证书是由未知的证书颁发机构问题签名的?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在开发c#应用程序来调用Exchange Management Shell Cmdlet.它总是出现“目标计算机上的服务器证书(208.243.XX.2XX:443)有以下错误
SSL证书由未知的证书颁发机构签名.
SSL证书包含与主机名不匹配的公用名(CN). “

但是我确实编写了接受所有证书的代码,不知道为什么还会得到错误.

我的代码

PSCredential credential = new PSCredential("administrator",securePwd);

    WSManConnectionInfo connectionInfo = new WSManConnectionInfo(new Uri("https://208.243.49.20/powershell"),"http://schemas.microsoft.com/powershell/Microsoft.Exchange",credential);
    connectionInfo.AuthenticationMechanism = AuthenticationMechanism.Basic;

    Runspace runspace = System.Management.Automation.Runspaces.RunspaceFactory.CreateRunspace(connectionInfo);
    PowerShell powershell = PowerShell.Create();
    PSCommand command = new PSCommand();
    command.AddCommand("New-MailBox");
    command.AddParameter("Name","TestName");
    powershell.Commands = command;
    ServicePointManager.ServerCertificateValidationCallback += new RemoteCertificateValidationCallback(
    delegate { return true; }
);
    try
    {
        runspace.Open();//This is where the exception happens
        powershell.Runspace = runspace;
        Collection<PSObject> result= powershell.Invoke();
    }

解决方法

WSManConnectionInfo对象有两个属性可以跳过证书检查.
connectionInfo.SkipCACheck = true;

connectionInfo.SkipCNCheck = true;

猜你在找的C#相关文章