陋室铭
永远也不要停下学习的脚步(大道至简至易)

我的应用程序(.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,所以应该给你你需要的隔离。

+0

感谢您确认我的担心,希望不会是这样。 – Rich 2010-09-27 07:37:50

+4

MS 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

posted on 2021-05-16 09:39  宏宇  阅读(801)  评论(0编辑  收藏  举报