https原理

首先说一下几个概念:对称加密、非对称加密

对称加密:

客户端和服务端使用同一个秘钥,分两种情况:

1、所有的客户端和服务端使用同一个秘钥,这个秘钥被泄漏后数据不再安全

2、每个客户端生成一个秘钥,如果客户端比较多,这样在服务端就有很多个秘钥,对服务端造成压力

非对称加密:

1、客户端和服务端使用不同的秘钥,服务端生成私钥和公钥,在客户端请求服务端建立连接时 服务端将公钥发给客户端,私钥只在服务端保存

2、私钥加密的公钥可以解密,公钥加密的私钥可以解密,公钥加密的公钥不能解密,私钥加密的私钥不能解密

公钥和私钥从哪里来:在服务端通过openSSL生成私钥,然后通过私钥再生成公钥,这样保证了私钥和公钥的关联

三次握手和四次握手:

客户端和服务端成功建立连接的过程叫做三次握手,建立连接之后客户端需要验证证书的合法性、生成 session secret 用于数据传输的对称加密等,具体步骤参考 HTTPS四次握手的过程-转载 - 知乎

Https的实现原理:

https的过程分为证书验证和数据传输阶段,具体交互过程如下,在证书验证阶段采用非对称加密,数据传输阶段采用对称加密,因为对称加密的效率高于非对称加密;

https是长链接,四次握手(证书验证)成功后就可以进行数据的传输了;

证书验证阶段:

客户端向服务端发起请求时服务端会返回一个证书,证书里面就包含了公钥,客户端验证证书是否合法,如不合法则会出现下面类似的提示,如果要继续访问也是可以的

数据传输阶段:

1、当客户端验证证书合法,则生成一个随机数

2、通过公钥加密随机数,把加密后的随机数发给服务端

3、服务端通过私钥对随机数解密,通过这个随机数构造对称加密算法,使用算法加密数据后返回

什么样的证书才是合法的?

只有CA认证的权威机构颁发 的证书才认为是合法证书,这样就避免了"中间人攻击"问题:

中间人攻击是在客户端和服务端之间穿件一个伪服务,客户端从这个伪服务中获取公钥、收发数据等,这个伪服务从真正的服务器上获得公钥和收发数据

因为伪服务不是一个CA认证的机构,它生成的证书就是一个无效证书,只有真正的服务器的证书才是有效的

证书的验证:

一个证书通常包含以下信息:颁发者机构、有效期、公钥、所有者、签名算法、指纹等

1、每份签发证书都可以根据验证链查找对应的根证书,操作系统、浏览器会在本地存储权威机构的根证书,利用本地根证书完成对应机构签发证书的验证

2、与 CA 服务器校验判断证书是否被篡改

3、通过 CRL和 OCSP验证判断证书是否已吊销

以上都满足的情况下才认为证书是合法的

相关推荐
不一样的故事12625 分钟前
下的 “Wi-Fi参数配置” 列表,但您当前选中的导航菜单项是 “IP规划”。您遇到的 “IP加载不出来” 问题,很可能
网络协议·tcp/ip·华为
我是苏苏1 小时前
Web开发:C#通过ProcessStartInfo动态调用执行Python脚本
java·服务器·前端
相偎3 小时前
Ubuntu搭建svn服务器
服务器·ubuntu·svn
咕噜企业分发小米3 小时前
有哪些开源的直播云服务器安全防护方案?
运维·服务器·云计算
开开心心_Every4 小时前
安卓后台录像APP:息屏录存片段,行车用
java·服务器·前端·学习·eclipse·edge·powerpoint
qq_316837754 小时前
IP网段冲突 配置指定ip使用指定的网络接口发送,而不经过默认网关
服务器·网络·tcp/ip
枷锁—sha5 小时前
彻底解决 Google Gemini 报错:异常流量与 IP 地址冲突排查指南
网络·网络协议·tcp/ip
深圳市恒讯科技5 小时前
Linux 文件权限指南:chmod 755、644、drwxr-xr-x 解析
linux·服务器·xr
xingzhemengyou16 小时前
Linux taskset指令设置或查看进程的 CPU 亲和性
linux·服务器
开开心心就好6 小时前
图片格式转换工具,右键菜单一键转换简化
linux·运维·服务器·python·django·pdf·1024程序员节