我的应用程序(.NET 3.5 SP1)使用HttpWebRequest具有不同端点进行通信,有时其通过HTTPS其中每个托管服务器可以具有不同的安全协议要求说TLS或SSL3或者其他。设置在.NET HttpWebRequest的所述SecurityProtocol(SSL3或TLS)每个请求
通常,服务器可以很好地协商/回退使用TLS或SSL3的SecurityProtocol,但有些不会,当.net设置为TLS或SSL3(默认情况下我认为)只支持那些服务器SSL3导致.net抛出发送错误。
从我可以告诉.NET提供了可设置为TLS,SSL3或两者性质SecurityProtocol的ServicePointManager对象。因此,理想情况下,当这两个想法是客户端和服务器应该谈判使用什么,但如前所述,似乎并没有工作。
据说你可以设置ServicePointManager.SecurityProtocol = SSL3但对于想要使用TLS终点?
我在ServicePointManager和SecurityProtocol中看到的问题是,它的静态和因此应用程序域广泛。
所以这个问题..
我将如何去使用HttpWebRequest具有不同SecurityProtocol例如
1)url 1 set to use TLS | SSL3(协商)
2)链接2设置为SSL3(仅SSL3)
不幸的是,它并不像你可以为每个服务点定制的。我建议你在这个区域的MS Connect网站上提交功能请求。
作为一个肮脏的解决方法,您可以尝试在新的appdomain中执行需要不同安全协议的站点。静态实例是每个appdomain,所以应该给你你需要的隔离。
来源
2010-09-25 23:19:28 feroze
+0感谢您确认我的担心,希望不会是这样。 – Rich 2010-09-27 07:37:50
+4MS Connect请求https://connect.microsoft.com/VisualStudio/feedback/details/605185/cant-set-the-security-protocol-per-servicepoint有状态“不会修复” – 2012-04-30 08:20:59
+0@MichaelFreidgeim如果现在看,Microsoft已经回复说它将在> Net Framework 4.7.1 - *中得到修复。在即将发布的.NET Framework 4.7.1中,我们已经在System.Net.HttpClient中使用的HttpClientHandler类中添加了新属性。这是用于HTTP请求而不是HttpWebRequest的首选API。这些新属性被添加以匹配.NET Core 2.0版本,该版本已经在HttpClientHandler上拥有较新的属性。“* – Lankymart 2017-11-06 11:42:34
http://cn.voidcc.com/question/p-tkdovgsv-b.html