【发布时间】:2012-08-01 13:43:03
【问题描述】:
我有一个第三方 Web 应用程序,现在我的经理想要将智能卡身份验证添加到某些页面(而不是整个应用程序)并返回证书信息。我在想的是向这些页面添加按钮,在onclick 事件中,我将进行客户端证书身份验证(将出现证书选择窗口,然后出现“PIN”窗口)并返回证书对象以供进一步加工。
我最初考虑使用 Web 服务来进行客户端证书身份验证并返回证书信息,这会很棒,因为我们可能会考虑在其他 Web 应用程序(在不同平台上)中使用该 Web 服务。但是,我找不到任何这样做的代码示例。然后我找到了IIS solution。
我现在创建了一个单独的文件夹,其中包含一个需要客户端证书的页面。在按钮单击事件中,我重定向到该页面。然后在该页面上,我使用 X509Certificate 类检索证书信息。我认为这对我正在尝试做的事情没有帮助,或者至少我不知道它有什么帮助。
所以我的问题是(抱歉,背景描述太长了)
- 如何从带有认证结果的页面重定向回来?
- 如果可能的话,任何关于如何构建一个 Web 服务的参考资料,该服务以与 IIS 相同的方式进行客户端证书身份验证?
谢谢
更新 我环顾四周,仍然不知道如何实现这一目标。我不确定如何在 SSL/TLS 握手阶段为 Web 服务编写代码。我也不知道如何将认证返回到我调用此函数的页面。所以我现在要做的是从需要客户端身份验证的受保护页面重定向。似乎 Web 服务器缓存了身份验证结果。这是我的第三个问题,希望有人能回答。
如何在页面会话结束时清除身份验证结果,以便每次访问该页面时,它都会请求客户端身份验证(其中会出现证书选择窗口,然后是“PIN”窗口)?
【问题讨论】:
标签: c# authentication iis client-certificates