- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个执行自定义客户端证书验证的 Asp.net API 网站。在 IIS 10 上托管此网站时,我在调用 API 时从失败的请求日志中得到以下信息。
A certificate chain processed, but terminated in a root certificate which is not trusted by the trust provider.
我的 web.config 有
<configuration>
<system.webServer>
<access sslFlags="Ssl, SslRequireCert" />
</system.webServer>
在 applicationHost.config 中我有
<section name="access" overrideModeDefault="Allow" />
我在这里缺少什么?如何将 IIS 配置为只传递证书而不验证证书?
我想这样做的原因是,这是一个测试环境,我想信任所有使用自签名证书调用我的 API 的客户。我将在我的 API 内部验证证书。
注意:我在 Azure AppService 上托管了同一个网站,并将“传入客户端证书”设置为ON。它就像一个魅力。 那么,当我在我的机器 IIS 上托管它时有什么区别?
最佳答案
我们使用客户端证书来验证连接到我们 API 的硬件设备。就上下文而言,我们的设备在制造时配备了 SSL 证书,并且该证书由我们自行签署。当外面的设备尝试连接到我们的 API 时,我们会在 .NET API 应用程序本身内处理客户端证书验证。
这需要以下 IIS SSL 设置,以及重新绑定(bind) SSL 绑定(bind)的手动步骤(我们这样做是为了解决非常具体的技术限制)。
所以首先,在 web.config 文件中我们有这个配置:
<security>
<access sslFlags="Ssl" />
</security>
如果我们添加 SslNegotiateCert 或 SslRequireCert sslFlags,那么 IIS 会在我们的应用程序代码被调用之前尝试验证客户端证书。所以我们只设置了 Ssl 标志。
其次,在IIS站点的SSL设置中我们设置:
需要 SSL [x]
客户端证书:
[x]忽略
[ ] 接受
[ ] 要求
所以本质上我们并不是要求 IIS 代表我们协商客户端证书。
我们所做的最后一个配置更改是在 SSL 绑定(bind)上启用“协商客户端证书”。默认情况下,当您在 IIS 中创建 SSL 绑定(bind)时,“协商客户端证书”属性设置为 false。
据我了解,这意味着 IIS 不会在初始 TLS 协商时协商客户端证书。当需要客户端证书时会发生什么,触发 TLS 重新协商,并且服务器会向客户端请求客户端证书。
在我们的例子中,我们的设备在初始请求时通过了客户端证书,并且不会处理 TLS 重新协商。因此,通过启用“协商客户端证书”,客户端证书可以在初始请求中传递。
所以重新绑定(bind) SSL 绑定(bind)需要一些命令行魔法来找到当前绑定(bind),删除它,并在启用“协商客户端证书”的情况下重新添加绑定(bind)。
第 1 步 - 找到您的 SSL 绑定(bind):
在CMD终端中运行以下命令:
netsh http 显示 sslcert > sslcerts.txt
这会将您当前 SSL 绑定(bind)的所有详细信息推送到 sslcerts.txt
文件将如下所示:
Hostname:port : yourhostname:443
Certificate Hash : your_certificate_hash
Application ID : {your_applicationID_Guid}
Certificate Store Name : My
Verify Client Certificate Revocation : Enabled
Verify Revocation Using Cached Client Certificate Only : Disabled
Usage Check : Enabled
Revocation Freshness Time : 0
URL Retrieval Timeout : 0
Ctl Identifier : (null)
Ctl Store Name : (null)
DS Mapper Usage : Disabled
Negotiate Client Certificate : Disabled
请注意,您的 sslcerts.txt 文件将包含这些绑定(bind)的许多实例。您需要为您正在使用的应用程序/网站找到正确的。
另请注意,上面的输出显示“协商客户端证书:已禁用”
第 2 步 - 删除当前绑定(bind)
运行以下命令删除当前绑定(bind)
netsh http delete sslcert 主机名端口=你的主机名:443
这将删除站点的 SSL 绑定(bind)。
第 3 步 - 在启用“协商客户端证书”的情况下重新绑定(bind) SSL
在 CMD 提示符下运行以下命令:
netsh http add sslcert hostnameport=yourhostname:443 certhash=your_certificate_hash appid={your_applicationID_Guid} certstorename=MY verifyclientcertrevocation=Enable VerifyRevocationWithCachedClientCertOnly=Disable UsageCheck=Enable clientcertnegotiation=Enable
请注意,除了设置 clientcertnegotiation=Enable 之外,您正在根据在 sslcerts.txt 中检索到的详细信息填写绑定(bind)的属性
现在我们有一个 IIS 应用程序,它将预先协商客户端证书,但不会验证它,并允许我们在代码中验证它。
然后我们使用 AuthorizationFilterAttribute 获取客户端证书并根据我们的规则对其进行验证。
public class ValidateDeviceClientCertificateAttribute : AuthorizationFilterAttribute
{
public override void OnAuthorization(HttpActionContext actionContext)
{
X509Certificate2 cert = actionContext.Request.GetClientCertificate();
// Validation rules here i.e. check Hash of the signing cert, does it match your accepted value?
}
}
在我们的验证中,我们有一个已知的中间 CA,我们用它来签署我们的设备证书,因此我们检查以确保客户端证书是由该中间证书或至少一个我们的设备签署中间证书签署的。
关于asp.net - 在 IIS 10 中禁用 Asp.net 网站的客户端证书验证,但允许应用程序请求传入的客户端证书,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54792256/
我试图对 ASP.Net MVC 有一个高层次的理解,我开始意识到它看起来很像原始的 ASP 脚本。过去,我们将“模型”/业务逻辑代码组织到 VBScript 类或 VB COM 组件中。 当然,现在
我已经搜索了一段时间,但似乎找不到答案。 我想在我的旋转木马中显示一个计数器,左边是当前项目(工作),左边是项目总数。 我的代码:
. 最佳答案 Scott Gu 称这些为代码块。这就是我的看法。 http://weblogs.asp.net/scottgu/archive/2010/04/06/new-lt-gt-syntax
我有一个使用 Visual Studio 2010/.net 4/VB 制作的网站。 我真的很喜欢我发现的 FAQ 系统的布局,因为它很简单,但它是经典的 asp。所以,显然,我不能包括我的母版页布局
好吧,对于你们许多人来说,这个问题可能有一个非常明显的答案,但它让我难住了。 我有一个 asp.net Web 表单,上面有两个控件(嗯,不止这两个,但我们将重点关注这些) - 第一个是 asp:dr
当我将 ASP.NET 复选框控件设置为 asp.net 更新面板的异步回发触发器时,EventName 属性是什么? 最佳答案 我相信它是 CheckedChanged。 关于asp.net - a
我有一个用经典 asp 编写的(巨大的)网站。现在我必须切换到 vb.net (razor)。有没有办法将这两个结合起来直到切换完成? 有没有办法让应用程序与经典的 asp 和 vb.net 一起工作
I am creating a products page, where the user selects an option in a radiobuttonlist for example, an
我最近将一个经典的 ASP 应用程序转换为 ASP.NET 3.5,但我觉得我的经典 ASP 版本要快一些(我不知道可能买家会后悔)。 所以你们能帮我解决这个问题吗,让我知道哪个更快,asp、asp.
从本周开始,我被要求开始学习如何使用 ASP 开发网站。我通过 XNA 对 C# 有一定的经验,所以这部分对我来说并不是什么麻烦。 我一直在关注Music Store Tutorial这需要我设置一个
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 8 年前。 Improve this ques
我想将一些表单变量发布到经典 ASP 页面中。我不想改变经典的 ASP 页面,因为需要完成大量的工作,以及消耗它们的页面数量。 经典的 ASP 页面需要将表单变量 Username 和 Userpas
已结束。此问题正在寻求书籍、工具、软件库等的推荐。它不满足Stack Overflow guidelines 。目前不接受答案。 我们不允许提出寻求书籍、工具、软件库等推荐的问题。您可以编辑问题,以便
在某种程度上,这可能是一个异端问题。我们有一个大型站点,其中许多页面仍在ASP中。通常,并没有真正动态的,而是包括(通过SSI或Server.Execute)定期重新生成的HTML块。看起来好像是一个
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 9 年前。 Improve this ques
我有一个遗留的 ASP 应用程序——在不久的某个时候——需要迁移到 ASP.Net 2.0(以与也在 2.0 中的其他应用程序兼容)。 对于这类事情是否有最佳实践,即作为第一步将当前 html、vbs
我目前在一家公司工作,该公司使用 ASP.NET Webforms 和旧 ASP 页面的组合进行 Web 开发。这对于他们当前的项目来说效果很好,但我想说服/建议他们切换到 ASP.NET MVC,因
我有一个经典的 asp 应用程序。我想将该页面的竞赛表格发布到 Asp.Net 表格。原因是我想在进入数据库之前使用我在 Asp.Net 页面中内置的大量逻辑进行验证,而我对 asp 不太了解。更不用
我知道在 ASP.NET MVC 中,您可以拥有移动 View 并执行类似 Index.mobile.cshtml 的操作。和 _Layout.mobile.cshtml并且服务器知道将这些 View
我需要从一些服务器端 c#.net 代码中调用经典 asp 页面上的 VBscript 函数 - 有谁知道一种干净的方法来做到这一点?在 .net 中重写函数不是一种选择。 我会再解释一下这个问题..
我是一名优秀的程序员,十分优秀!