对于安装在本机上的根证书的进一步了解

2024-02-15 17:38

本文主要是介绍对于安装在本机上的根证书的进一步了解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

以前写过一篇文件,描述的是为什么会出现HTTPS与根证书这种东西,那篇文章的描述还是很详细的,地址是http://blog.csdn.net/sundacheng1989/article/details/25540601

 

最近在做一个WCF项目的时候,又遇到了根证书问题,而且在测试阶段还需要使用自认证的证书,这次就又继续研究了一下装在本机电脑上的根证书。首先要纠正一下我以前的错误概念,以前一直认为安装在本机上的是浏览器与服务器交互的时候,用到的那个证书。其实这个理解是错误的,安装在本机上的,叫做根证书,确切的说,是一个可信任的证书颁发机构,或者说这个根证书是一个可信任的证书颁发机构的唯一身份标识。

 

如果我们打开IE浏览器的证书列表查看,会看到在Trusted Root Certification Authorities列表中,看到很多机构的信息。这些都是可信任的证书颁发机构。在这里,我们可以对根证书,或者说对这些证书机构进行导出,可以看到导出的文件格式是cer格式,这就说明以后我们在安装这类程序的时候,安装的是可信任机构,或者是安装的是可信任机构颁发的证书凭证(其实也包括不可信任机构颁发的证书凭证)。

 

 

 

换句话说,一个认证机构在一个客户机器上,显示方式就是一个证书,或者说一个机构。可以看到,认证机构的代表就是cer,也就是说,认证机构跟根证书是一回事。

 

但是这里又出现了一个Personal的证书,这个又是什么呢?这个是具体的公司的识别标志。这里来说一下这个层次关系。认证机构比如说Global Sign,会颁发证书给B公司,那么你现在显示的Personal列表里边就包括这个B公司的证书凭证。简单的讲,这里所看到的所有的证书,都可以理解为是根证书,是用来验证每一次http请求的时候,服务器端发送给浏览器的证书是否是正确的。

 

每一次的https请求,都会有服务器端发送证书给浏览器端的过程,https://www.wosign.com/FAQ/faq2016-0309-04.htm. 因为每一次请求,都有一个SSL握手的过程。

 

这里列举一个特殊的情况,还是拿12306举例子。因为客户机上没有安装任何铁道部的证书信息,访问页面的时候,服务器发送过来一个临时证书,浏览器找不到这个公司的证书凭证,所以Chrome或者其他浏览器都会报出Https不安全警告。这里再介绍另一个例子。比如说B公司有了证书凭证,也在浏览器上安装了,但是这个证书是一个野鸡公司颁发的,也就是说,根证书机构没有安装在本机上,所以,也会抛出不安全警告。

自认证证书就是这个例子。一个公司,自己给自己颁发了一个证书,在Personal列表中有了这个证书凭证,查看其根证书机构SUNROBIN,还是自己这个公司,根本不是公认的机构,所以浏览器就会觉得,这个证书凭证不可以信任。但是自认证证书在开发Https网站的时候,用于测试目的还是很方便的,省的去花钱搞真的证书。

上一个项目是一个SharePoint的项目,SharePoint中相关JS发起的向其他网站或者WCF服务的请求都是必须要Https方式的。用例子来说,如果SharePoint的js脚本中向WCF获取数据,SharePoint中必须是https请求。所以相应的WCF就必须提供https服务。

我们在开发阶段怎么做?我们可以创建一个自认证的证书,然后安装到本机上,创建自认证证书的第三方工具很多,可以选其一。创建完成后,这样,浏览器就有了相关的证书凭证。但是这些操作仅仅是从客户端的角度,安装到了证书列表。

我们在使用自认证证书创建工具创建的时候,生成的东西分为两部分,一部分需要安装在浏览器相关的地方,也就是说跟客户端相关。另一部分,是WCF服务提供HTTPS服务的时候,需要借助这一部分对http回复请求进行加密。我们在使用WCF开启服务的时候,也要使用证书对消息进行加密。

感觉自认证的证书跟机构认证的在行为方式上没有太多区别,只是你安装到浏览器的时候,会包含认证机构信息,浏览器会查到这个机构,然后浏览器厂商会有自己的标准判断这个机构是否可信任。比如说自认证的,以及铁道部的根证书(机构),浏览器会认为不可信任,给你红色警告。

 

 

如何创建自认证的证书 https://blog.didierstevens.com/2008/12/30/howto-make-your-own-cert-with-openssl/

 

自认证证书危险的方面 https://www.globalsign.com/en/ssl-information-center/dangers-self-signed-certificates/

 

这篇关于对于安装在本机上的根证书的进一步了解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/712071

相关文章

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

Python安装时常见报错以及解决方案

《Python安装时常见报错以及解决方案》:本文主要介绍在安装Python、配置环境变量、使用pip以及运行Python脚本时常见的错误及其解决方案,文中介绍的非常详细,需要的朋友可以参考下... 目录一、安装 python 时常见报错及解决方案(一)安装包下载失败(二)权限不足二、配置环境变量时常见报错及

MySQL8.2.0安装教程分享

《MySQL8.2.0安装教程分享》这篇文章详细介绍了如何在Windows系统上安装MySQL数据库软件,包括下载、安装、配置和设置环境变量的步骤... 目录mysql的安装图文1.python访问网址2javascript.点击3.进入Downloads向下滑动4.选择Community Server5.

CentOS系统Maven安装教程分享

《CentOS系统Maven安装教程分享》本文介绍了如何在CentOS系统中安装Maven,并提供了一个简单的实际应用案例,安装Maven需要先安装Java和设置环境变量,Maven可以自动管理项目的... 目录准备工作下载并安装Maven常见问题及解决方法实际应用案例总结Maven是一个流行的项目管理工具

MySql9.1.0安装详细教程(最新推荐)

《MySql9.1.0安装详细教程(最新推荐)》MySQL是一个流行的关系型数据库管理系统,支持多线程和多种数据库连接途径,能够处理上千万条记录的大型数据库,本文介绍MySql9.1.0安装详细教程,... 目录mysql介绍:一、下载 Mysql 安装文件二、Mysql 安装教程三、环境配置1.右击此电脑

在 Windows 上安装 DeepSeek 的完整指南(最新推荐)

《在Windows上安装DeepSeek的完整指南(最新推荐)》在Windows上安装DeepSeek的完整指南,包括下载和安装Ollama、下载DeepSeekRXNUMX模型、运行Deep... 目录在www.chinasem.cn Windows 上安装 DeepSeek 的完整指南步骤 1:下载并安装

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

龙蜥操作系统Anolis OS-23.x安装配置图解教程(保姆级)

《龙蜥操作系统AnolisOS-23.x安装配置图解教程(保姆级)》:本文主要介绍了安装和配置AnolisOS23.2系统,包括分区、软件选择、设置root密码、网络配置、主机名设置和禁用SELinux的步骤,详细内容请阅读本文,希望能对你有所帮助... ‌AnolisOS‌是由阿里云推出的开源操作系统,旨

Ubuntu系统怎么安装Warp? 新一代AI 终端神器安装使用方法

《Ubuntu系统怎么安装Warp?新一代AI终端神器安装使用方法》Warp是一款使用Rust开发的现代化AI终端工具,该怎么再Ubuntu系统中安装使用呢?下面我们就来看看详细教程... Warp Terminal 是一款使用 Rust 开发的现代化「AI 终端」工具。最初它只支持 MACOS,但在 20

mysql-8.0.30压缩包版安装和配置MySQL环境过程

《mysql-8.0.30压缩包版安装和配置MySQL环境过程》该文章介绍了如何在Windows系统中下载、安装和配置MySQL数据库,包括下载地址、解压文件、创建和配置my.ini文件、设置环境变量... 目录压缩包安装配置下载配置环境变量下载和初始化总结压缩包安装配置下载下载地址:https://d