I'm trying to add the following line of code to the Global.asax file in a website project.
System.Net.ServicePointManager.SecurityProtocol = System.Net.SecurityProtocolType.Tls12;
The vs2012 IntelliSense is showing that Tls12 definition exist. But the build is saying that the definition does not exist (See screen shot).
I've tried adding System.Net.dll to the bin folder of the project, but the build still failed. Any idea how I might be able to resolve this?
TLS and How to avoid connection errors.
Personally on my .Net 4.0 Framework with some asp classic files I used:
https://blogs.perficient.com/2016/04/28/tsl-1-2-and-net-support/
Are you on .net 4.0? You should be at least 4.5 to use it. You can try to update your web target framework version: TLS 1.2 in .NET Framework 4.0
Website is already on .Net 4.5, Later updating the Compilation > TargetFramework manually from 4.0 to 4.5 fixed the issue for me.
Here's is the updated configuration
About your concerns which version of TLS your application(client) and the server you are trying to connect will use.
Directly quoted from the RFC 5246 standard for TLS.
During
ClientHello
(first request client makes to the server)During
ServerHello
(first request that server responds with)ClientHello
andServerHello
are structures with fields which are described in the standard here.TL;DR
When using
System.Net.WebRequest
your application will negotiate with the server to determine the highest TLS version that both your application and the server support, and use it.Regarding your question.
SecurityProtocolType.Tls11 and SecurityProtocolType.Tls12 enum values are missing on Framework 4.0 only.
SecurityProtocolType numeric values:
SystemDefault (0)
Ssl3 (48 - 0x30)
Tls (192 - 0xC0)
Tls11 (768 - 0x300) missing on Framework 4.0
Tls12 (3072 - 0xC00) missing on Framework 4.0
On Framework 4.0, if want to allow TLS 1.0, 1.1 and 1.2, just replace:
by: