问一个客户端证书的问题

mazhanshan10 2010-07-02 06:57:15
各位大侠,小弟工作遇到问题,特来拜山,还望各位老哥哥不吝赐教。

公司做的系统现在想要添加客户端证书验证的功能,其实就是在IIS服务器上设置了要求用户使用客户端证书之后,在程序里读取用户证书里面一些信息:用户名,电子邮件和公司名称。

一开始我觉得不难,找到证书里面的Subject域之后,读出来 OU, E, CN,三个字段就可以了,可是后来发现,似乎这只是一种格式,在网上看到很多其他的证书,格式各种各样, 有的压根没有E这个字段,电子邮件地址存放在了SubjectAltName里面,有的电子邮件放在CN里面 (CN=hostName/Email=xxx@xxx.xx)。而用户名和公司名称也有时候会在别的地方存着。

这一来我就糊涂了,如果我想要读出来这三个信息并且和系统里面的信息对比验证,那岂不是要把所有的域都读取一遍,挨个儿比较?为什么证书不是统一格式? 他们不应该都是X509标准的吗?难道这中间有什么我理解不对的地方?

最后一点,会有多少情况一个通过SSL连接的网站会允许用户使用各种各样认证机构颁发的证书?还是一般都只会接受一个指定认证机构的证书?

再次拜谢,恭候解答。
...全文
65 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
lextm 2010-07-03
  • 打赏
  • 举报
回复
X509是一个很松散的标准,对于每个字段里面到底存什么,证书颁发机构有很大的自由度。

鉴于你的情况,最好是约定只有一个或有限几个颁发机构的证书能够用来访问这个网站,这样多少你知道一些规律。

据我所知,很多网站都仅仅接受有限的CA的证书。仅仅接受一个CA的情况也很常见。

62,266

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧