我正在使用邮差测试我有一个API,当请求不包含子域时,一切都很好,然而,当我添加一个子域到URL时,我得到了这个响应。

无法得到任何回应 连接http://subdomain.localhost:port/api/时出错 为什么会发生这种情况: 服务器无法发送响应:请确保后端正在工作 正确 自签名SSL证书被阻止:通过关闭来修复此问题 “SSL证书验证”设置>通用 Proxy配置错误确保Proxy配置正确 在“设置”中>代理 请求超时:在“设置”中修改请求超时时间

如果我从邮差复制相同的URL并将其粘贴到浏览器中,我得到了一个正确的响应,是否有某种配置,我应该做邮差工作与子域?


当前回答

如果您使用asp.net core 2应用程序,解决方案非常简单。在startup.cs文件中的ConfigureServices方法中这一行

services.AddMvc()
                .SetCompatibilityVersion(CompatibilityVersion.Version_2_1)
                .AddJsonOptions(x => x.SerializerSettings.ReferenceLoopHandling = Newtonsoft.Json.ReferenceLoopHandling.Ignore);

其他回答

在我的例子中,它是邮递员没有识别的无形空间,上面的文本字符串呈现为邮递员没有空格。 我禁用了SSL证书验证和系统代理,甚至尝试了邮递员chrome扩展(即将被弃用),但当我下载并尝试失眠症时,它在那些空格的地方给出了那些红点,一定是在复制/粘贴期间得到的

您提到您使用的是CER证书。

根据邮差证书页面。

在CRT文件字段中选择客户端证书文件。目前,我们只支持CRT格式。对其他格式(如PFX)的支持很快就会到来。

扩展名CER, CRT不会让证书成为那种类型的证书但是,这些是例外的扩展名。

CER是二进制形式的X.509证书,DER编码。

CRT是一个二进制X.509证书,封装在文本(base-64)编码中。

通过OpenSSL可以将CER文件转换为CRT文件。我的运气不太好,但它看起来是这样的。

openssl x509 -inform PEM -in证书。输出certificate.crt

or

openssl x509 -通知DER -in证书。输出certificate.crt

当用户不小心复制/粘贴了用于构建URL的环境变量中的前导空格字符时,我们得到了这个令人困惑的错误:

例子:

The request's URL was set to: http://{URL}/blah

The {URL} environment variable had a value of " hostname" (**notice the leading space character**)

这导致邮差试图访问http:// hostname/blah,并给出这个错误消息。

我也有同样的问题。这是由“Authorization”报头值末尾的换行符引起的,我通过复制粘贴承载令牌手动设置了换行符(意外地在其末尾包含换行符)。

在所有上述方法(如关闭SSL证书验证,只打开使用系统代理和删除HTTP_PROXY和HTTPS_PROXY系统环境变量)之后,它起作用了。

注意:必须重新启动邮递员应用程序,因为环境变量被改变了。