对https的基本认识

为什么需要https

由于http是明文传输,所以在发送端与接收端的任意节点(路由器,代理服务器)都知道传输的内容。当用户登陆账号和密码时,密码很容易被这些节点盗取,就算在发送端进行加密,别人仍然可以用加密后的账号密码登陆。


https是如何保障安全的

https实际上是secure http,即http的安全升级版。http是应用层协议,位于http协议之下的就是传输层tcp,http定义了数据如何包装,tcp负责传输,https则在http与tcp中间加了一层加密层TSL/SSL(TSL是SSL的升级版),对数据进行加密。


https是如何加密数据的

  • 对称加密

    加密和解密用的秘钥一样
    优点:加密和解密效率高;
    缺点:发送方和接收方需要协商、共享同一把秘钥,并确保秘钥不泄露出去,对于有多个数据交换需求的个体,两两之前需要分配并维护同一把秘钥,成本非常高。

  • 非对称加密

    加密(公)和解密(私)用的秘钥不一样
    通过公钥加密的数据,只能通过私钥解开。通过私钥加密的数据,只能通过公钥解开。浏览器利用公钥对账户密码加密,服务器利用私钥解密,验证通过,之后再通过私密加密后的个人信息返回给浏览器,浏览器利用公钥解密,由于公钥是公开的,中间代理服务器拿到了公钥后,毫不犹豫的就可以解密数据,因此非对称加密只能保证单向数据传输的安全性


https工作原理

  1. 浏览器将自己支持的一套加密规则发送给网站后台

  2. 网站后台从中选出一组加密算法与HASH算法,并将自己的身份信息以证书的形式发回给浏览器。证书里面包含了网站地址,加密公钥,以及证书的颁发机构等信息。

  3. 浏览器获得网站证书之后浏览器要做以下工作:
    a) 验证证书的合法性(颁发证书的机构是否合法,证书中包含的网站地址是否与正在访问的地址一致等),如果证书受信任,则浏览器栏里面会显示一个小锁头,否则会给出证书不受信的提示。
    b) 如果证书受信任,或者是用户接受了不受信的证书,浏览器会生成一串随机数的密码,并用证书中提供的公钥加密。
    c) 使用约定好的HASH算法计算握手消息,并使用生成的随机数对消息进行加密,最后将之前生成的所有信息发送给网站

  4. 网站接收浏览器发来的数据之后要做以下的操作:
    a) 使用自己的私钥将信息解密取出密码,使用密码解密浏览器发来的握手消息,并验证HASH是否与浏览器发来的一致。
    b) 使用密码加密一段握手消息,发送给浏览器

  5. 浏览器解密并计算握手消息的HASH如果与服务端发来的HASH一致,此时握手过程结束,之后所有的通信数据将由之前浏览器生成的随机密码并利用对称加密算法进行加密。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值