小编Ros*_*ieC的帖子

当SMPT服务器具有有效证书时,"根据验证过程"获取"远程证书无效"

这似乎是一个常见的错误,但是当我找到一个解决方法(见下文)时,我无法确定我首先得到它的原因.

我正在将SMTP功能写入我们的应用程序,并且我正在尝试将SSL功能添加到我们已有的工作SMTP中.

我正在测试使用我们公司的MS Exchange服务器,特别是在其上启用的webmail选项.我可以通过我的代码在内部发送电子邮件,不通过身份验证我的连接并匿名发送,但是由于我们公司的政策,这些电子邮件不会转发到外部电子邮件地址.除此之外,我正在为我们的客户编程,他们并不都允许开放中继和/或匿名连接.

我相信Exchange服务器正在使用显式SSL/TLS.我已经尝试telnet到端口25上的服务器地址并获得文本响应,人类可读的响应,根据我以前的一些搜索意味着它使用显式SSL/TLS.

我有以下测试代码

SmtpClient SMTPClient = new SmtpClient(webmailaddress);
SMTPClient.Port = 25;
SMTPClient.UseDefaultCredentials = true;
SMTPClient.EnableSsl = true;
System.Net.Mail.MailMessage Message = new `
System.Net.Mail.MailMessage(emailFrom,emailTo,subject,body);
SMTPClient.Send(Message);
Run Code Online (Sandbox Code Playgroud)

在我搜索解决方案期间,我遇到了"远程证书根据验证程序无效".使用Gmail SMTP服务器

从中我得到以下代码......

ServicePointManager.ServerCertificateValidationCallback = new RemoteCertificateValidationCallback(ValidateServerCertificate);

public static bool ValidateServerCertificate(object sender,X509Certificate certificate,X509Chain chain,SslPolicyErrors sslPolicyErrors)
{
    if (sslPolicyErrors == SslPolicyErrors.None)
        return true;
    else
    {
        if (System.Windows.Forms.MessageBox.Show("The server certificate is not valid.\nAccept?", "Certificate Validation", System.Windows.Forms.MessageBoxButtons.YesNo, System.Windows.Forms.MessageBoxIcon.Question) == System.Windows.Forms.DialogResult.Yes)
            return true;
        else
            return false;
    }
}
Run Code Online (Sandbox Code Playgroud)

这适用于我的测试代码.然而,我正在编写的实际过程(而不是我的测试代码)将在后台运行,并且无法真正询问用户(而是报告Windows错误日志中的错误).

在我开始时,我的问题就是为什么我会收到这个错误.如果我在浏览器中访问https:webmail.ourdomain.co.uk,它会显示一个有效的证书,并且没有安装证书的选项(正如我自己签署的那样).

证书截图 然而,当我运行我的代码,并在ValidateServerCertificate方法调试中断Poing的,我看证书的价值观和看到我们的本地服务器的发行人"之前没有使用",且性能"后,不使用"今天.这与我得到的证书不符.

我还检查了ValidateServerCertificate调试中的sslPolicyErrors标志,它们显示"RemoteCertificateChainErrors"和"RemoteCertificateNameMismatch".

那么我对此缺少什么...为什么它没有使用正确的证书?如果我需要在本地安装证书才能使用它,那么我需要了解它们,这样我就可以告诉客户如果他们得到了这个,该怎么做.

我不想通过从ValidateServerCertificate方法返回true来绕过检查,并且因为它是后台进程我不能问用户,所以我需要了解如何让我的代码使用正确/可信证书.

希望有人可以提供建议.

c# email ssl client-certificates smtpclient

15
推荐指数
2
解决办法
10万
查看次数

编译器警告CS1591"缺少XML注释"没有显示,我想要它

我搜索过并且只发现了想要抑制此警告的人提出的问题,例如Visual Studio禁用缺少XML注释警告,或者如何仅针对某些类型的成员显示它,或者如何将其添加到私有成员.

但是对于我来说,这个警告从来没有在我的任何Visual Studio副本中显示出来......我想要它.直到今天我才知道警告存在.我想记录我的代码,并想知道我没有错过任何地方.

使用上面的链接,我已经完成了在接受的答案中禁用它的建议,并且检查了在我不知情或没有记住的情况下这些都没有完成.

然而,在我近年来使用的Visual Studio的所有副本VS2013 Pro和VS2013 Express以及VS2015社区中都发生了这种情况(或者没有发生).并且在许多项目中都是一样的,包括我从头开始创建的项目以及从其他开发人员继承的项目.

在这些版本中是否需要执行某些操作才能启用它?我很困惑为什么我没有看到它.

c# visual-studio

4
推荐指数
2
解决办法
1469
查看次数

TFS合并特定更改集-缺少更改集

谷歌搜索和特定的库存溢出搜索都没有找到我这个问题的人。

在tfs中,我们的过程是,我们在称为Dev的分支中进行更改,而不是稍后将特定更改集合并到称为DevQA的分支中。(我们还有其他分支,目前不应该影响任何事情。)我们使用VS中可用的屏幕来执行此操作。

我上周做了9个变更集(所有变更集都与相同或至少重叠的代码有关),现在是时候将其中一些合并到DevQA了。

更改显示在Dev的“历史记录”中,但是当我选择合并时,然后选择特定的更改集(将源设置为Dev,将目标设置为DevQA),然后单击“下一步”,可用于合并的更改集列表不包括我的9个更改中的7个集,包括我要合并的集。

我已经做了一些检查,它们似乎是唯一缺少的变更集,其他变更集已经被合并,或者在列表中可用。

我单击了一个变更集,并使用了“跟踪变更集”和“可视化”选项,它显示变更集尚未合并。

进行这些变更集后,将创建一个新分支,该分支是从DEV分支出来的,而我的变更集显示在其中。但是我不认为这是相关的,因为其中的其他变更集可以合并到DevQA中。

这些可能没有出现吗?有什么办法可以解决这个问题,并迫使他们合并吗?

merge tfs visual-studio

4
推荐指数
1
解决办法
3937
查看次数

标签 统计

c# ×2

visual-studio ×2

client-certificates ×1

email ×1

merge ×1

smtpclient ×1

ssl ×1

tfs ×1