在asp.net中实现证书授权

如何解决在asp.net中实现证书授权

| 首先,我为我的英语不好对不起。 在过去的两天里,我读了很多书,但没有找到解决我问题的方法。 我需要实施这样的授权:  用户打开网页,出现特殊形式。在此表单上,只有一个按钮“选择证书文件”。 用户单击它时-他必须选择证书文件,该文件将用于授权。该文件必须是 存储在闪存驱动器等上。不在计算机硬盘驱动器上。 我读到有关cer / pfx文件的信息,但是关于这种模型却一无所知。 可能无法使用.net中的此类来做到这一点
System.Security.Cryptography.X509Certificates.X509Certificate
System.Security.Cryptography.X509Certificates.X509Certificate2
同时将在此站点上执行表格授权, 因此用户可以选择授权方式。 更新: 我认为这些类不能用于此模型。你能告诉我其他吗?     

解决方法

首先,您将需要一个启用SSL的网页。您无法使用随附的开发Web服务器(cassini)对其进行开发。可以使用IIS Express或本地IIS实例来开发这样的身份验证模型。无法直接从您的代码控制SSL身份验证,它取决于IIS网页文件夹设置。看一下这篇文章。 对于GUI体验,证书通常存储在证书存储区中,该存储区是安全的,并且不能从客户端页面/脚本内进行控制。当Web浏览器收到客户端证书协商请求的响应时,将显示特定于浏览器/平台的对话框,其中显示所有兼容的客户端证书。在服务器端,您可以通过从受信任的证书颁发机构安装适当的根证书来控制客户端可以选择哪些证书。但是,您无法控制客户端可以选择哪些证书(天气存储在受支持的智能卡中还是本地存储在硬盘驱动器中)。 更新 就您而言,我认为在Web浏览器中通过客户端身份验证的HTTPS会话无法实现所需的功能,因为您无法控制它如何管理其证书存储。 但是,如果您开发了一个插件,可以访问客户端USB驱动器上的便携式证书存储,则可以这样做。我认为我将使用在后台运行的JAVA小程序,并创建可以从页面的javascript访问的公共API,其原因如下: 可用多个 平台/浏览器 可以完全运行 启用S​​SL的网页中的信任模式 可以威胁PFX文件作为证书 商店(请参阅) 您将需要自己实现身份验证/握手部分,例如,使小程序使用XMLDSIG(可以包含歌手的公钥并受支持)对XML文档/片段(也可以包含用户名和密码哈希值)进行签名。在.net中)。成功验证签名的XML后,您可以将正常的身份验证cookie返回给客户端。     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?