简单 HTTPS 请求中的 System.Net.WebException

问题描述 投票:0回答:3

我遇到了 C# 和简单 HTTPS 请求的问题...

我想请求这个 URL:https://api.sipgate.com/v1/ 在网络浏览器中它工作正常,但我的 C# 代码不起作用:( 有人知道我做错了什么吗?谢谢你!

using System.Net;
using System.IO;

// [...]

WebRequest req = WebRequest.Create("https://api.sipgate.com/v1");
req.ContentType = "application/json";

try {
    WebResponse res = req.GetResponse();  // Exception here...
    Stream content = res.GetResponseStream();
    Console.WriteLine((new StreamReader(content)).ReadToEnd());
} catch (Exception e) {
    Console.WriteLine(e.ToString());                
}

这里是例外:

System.Net.WebException: Die zugrunde liegende Verbindung wurde geschlossen: Unerwarteter Fehler beim Senden.. ---> System.IO.IOException: Fehler bei Authentifizierung, da die Gegenseite den Transportstream geschlossen hat.
   bei System.Net.Security.SslState.StartReadFrame(Byte[] buffer, Int32 readBytes, AsyncProtocolRequest asyncRequest)
   bei System.Net.Security.SslState.StartReceiveBlob(Byte[] buffer, AsyncProtocolRequest asyncRequest)
   bei System.Net.Security.SslState.ForceAuthentication(Boolean receiveFirst, Byte[] buffer, AsyncProtocolRequest asyncRequest)
   bei System.Net.Security.SslState.ProcessAuthentication(LazyAsyncResult lazyResult)
   bei System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)
   bei System.Net.TlsStream.ProcessAuthentication(LazyAsyncResult result)
   bei System.Net.TlsStream.Write(Byte[] buffer, Int32 offset, Int32 size)
   bei System.Net.PooledStream.Write(Byte[] buffer, Int32 offset, Int32 size)
   bei System.Net.ConnectStream.WriteHeaders(Boolean async)
   --- Ende der internen Ausnahmestapelüberwachung ---
   bei System.Net.HttpWebRequest.GetResponse()
   bei Sipgate_Test.Program.Main(String[] args) in c:\users\abc\documents\visual studio 2017\Projects\def\hij\Program.cs:Zeile 24.

System.Net.WebException:

由于对方关闭了传输流,导致身份验证错误。

c# .net web https request
3个回答
8
投票

您缺少对 SSL 的支持。

ServicePointManager.ServerCertificateValidationCallback = delegate { return true; };
ServicePointManager.SecurityProtocol = SecurityProtocolType.Ssl3 | SecurityProtocolType.Tls | SecurityProtocolType.Tls11 | SecurityProtocolType.Tls12;

using (WebClient Client = new WebClient())
    string Content = Client.DownloadString("https://api.sipgate.com/v1");

编辑: 感谢@Crowcoder 指出这一点。在生产环境中,您不应该接受任何未经验证的证书。

ServerCertificateValidationCallback
提供了一种访问您通常无法访问的 SSL 证书信息的方法。 例如,参数
error
为您提供特定的证书错误,例如名称不匹配。参数
chain
为您提供服务器发送的确切证书链,当系统存储缺少中间CA证书时,可以使用该参数构建证书链。

ServicePointManager.ServerCertificateValidationCallback += 
    (s, cert, chain, error) =>
{
    return error == SslPolicyErrors.None;
};

1
投票

您可以使用

ServicePointManager
检查证书并验证它是否是您期望的证书,例如通过指纹或主题名称。

但是,如果您信任该站点,通常您会在服务器上安装证书。

在Chrome开发工具的安全选项卡中,您可以下载证书,然后将其安装在服务器上。您将需要链中的所有证书,如

Certification Path
选项卡所示。


0
投票

我们遇到了同样的错误,因为该项目仍然是 4.5 版本的 .NET Framework。 4.5 默认使用 TLS 1.0。我们更改为 4.8,它使用 TLS 1.2,并且立即生效。

© www.soinside.com 2019 - 2024. All rights reserved.