http和https的区别是什么?

"http"是什么?

http也相当于HTTP协议,英文全称是Hyper Text Transfer Protocol,是超文本传输协议的意思。http协议它不仅保证计算机正确快速地传输超文本文档,还确定传输文档中的哪一部分,以及哪部分内容首先显示

"https"是什么?

https相当于HTTPS协议,英文全称Hyper Text Transfer Protocol over SecureSocket Layer,超文本传输安全协议的意思。HTTPS 存在不同于 HTTP 的默认端口及一个加密/身份验证层(在 HTTP

http"和“https”区别是什么?

1、"http"和"https"都是超文本传输协议,但不同的是"https"是加安全协议,所以跟多用于敏感的通信,比如交易场景。

2、https主要由两部分组成:http+ SSL / TLS,也就是在 http上又加了一层处理加密信息的模块。

3、https协议是由SSL+http构建的可进行加密传输、身份认证的网络协议,要比 http安全,可防止数据在传输过程中被窃取、改变,确保数据的完整性

与 TCP 之间)。这个系统提供了身份验证与加密通讯方法

一、传输信息安全性不同

1、http协议:是超文本传输协议,信息是明文传输。如果攻击者截取了Web浏览器和网站服务器之间的传输报文,就可以直接读懂其中的信息。

2、https协议:是具有安全性的ssl加密传输协议,为浏览器和服务器之间的通信加密,确保数据传输的安全。

二、连接方式不同

1、http协议:http的连接很简单,是无状态的。

2、https协议:是由SSL+HTTP协议构建的可进行加密传输、身份认证的网络协议。

三、端口不同

1、http协议:使用的端口是80。

2、https协议:使用的端口是443

无连接是指:
http协议每次只能处理一个请求,限制我们每次连接只处理一个请求,就是服务器处理完客户的一个请求,并且收到客户的应答之后就会断开连接,即一个连接处理一个请求。后续再有其他请求需要重新发起连接。

它采用这种方式啊,其实是为了节省时间,但是一般web页面都比较复杂,可能需要在一个连接里面要处理多个请求,这时就不希望处理完一个请求,就断开连接,而是希望一个连接里面要去处理多个请求,于是在这个协议里面定义了一个新的功能叫做keep alive机制,它就可以让我们的一个连接保持。我们让它保持之后呢,它就变成了一个长链接。

无状态是指:
就是这个协议对于客户端是没有任何的记忆能力,那它导致一个问题,例如一个请求,断开了,没有保留本次请求里面的一个消息。然后下一个请求又来了。那么此时要用到上一个请求的东西怎么办?这时候就需要重新传输。

比如说使用淘宝,用户需要先进行登录,然后再去购买商品,那登录是一个请求,购买商品又是另外一个请求,那购买商品的时候是不是一定要先登录,这时就希望他能够给我保留一些登录相关的信息,怎么办呢?这时候我们应该采取一些什么样的机制来进行呢?就是一个cookie的机制和一个session的一个机制。

明文就是没有加过密的报文。所以账号密码都可以看见,非常的不安全,也不会对双方的“身份”进行认证。比如说我们有一个客户端,要想跟服务器进行一个通信,那中间如果有一个第三者,它就做了一个截取消息,篡改消息,因为客户端和服务器它并没有进行身份认证,所以中间第三者他可以把这个消息窃取到,进行修改之后再发给服务器。这是一个很不安全的地方,这就是http协议的一个非常明显的一个缺点。基于这个缺点HTTPS(全称:Hyper Text Transfer Protocol Secure)应运而生,就是超文本传输安全协议。

ttp + 加密 + 身份认证 + 完整性 = HTTPS

https协议是基于tcp的443端口。我们经常把https协议叫做披着ssl协议外壳的http协议。http协议和https协议都是基于TCP协议的,但是对于https协议呢,它是先有一个ssl协议的,它需要先有1个ssl封装加密。HTTPS网络中数据包的封装的过程:先封装一个ssl协议头部,然后再去封装一个http协议

,所以它需要先去基于1个ssl加密的,然后呢在这个加密的基础上面发送http的消息。

本质区别

第一:安全性

    从安全性角度, https协议是比http协议安全的,因为http是明文,易受攻击,也没有办法认证身份,也没有办法保证数据的完整性,https协议呢?它密文加密了,还能认证身份,还能防止消息被篡改,对安全性是非常高的。这是他们两个的第一个非常重要的区别.

第二:灵活性

    http是tcp的80端口,https是tcp的443端口,灵活性不同, http协议也没有复杂的握手过程,https因为ssl这个协议的实现过程比较复杂,有一些加密,有些密钥的计算,有一些很复杂的技术在里面,所以它的技术门槛比较高,如果你要基于这个技术去开发一个网站的话,它的技术要求会比较高。

第三:速度

    很明显http协议速度肯定快。因为它不需要经过复杂的ssl的握手,所以它的速度非常快。https协议需要经过一些复杂的安全过程,所以需要服务器性能好,服务器如果资源不够,都没有办法承载这个复杂的加密算法,也会导致我们用户的访问速度会比较慢.

第四:经济适用度

    就是http协议,它没有一些额外的费用。但是呢,https协议,要去CA颁发证书,这个需要花钱的,年费大概是600到1000左右,还需要一些技术支持等费用,它是比较贵的,https优势这么明显,但是仍然有一些网站,像有一些小公司,由于对服务器要求比较高,可能就承担不起.

HTTPS 默认工作在 TCP 协议443端口,它的工作流程一般如以下方式:

1、TCP 三次同步握手

2、客户端验证服务器数字证书

3、DH 算法协商对称加密算法的密钥、hash 算法的密钥

4、SSL 安全加密隧道协商完成

5、网页以加密的方式传输,用协商的对称加密算法和密钥加密,保证数据机密性;用协商的hash算法进行数据完整性保护,保证数据不被篡改。

HTTPS 的工作原理

1、客户端发起 HTTPS 请求

用户在浏览器里输入一个 https 网址,然后连接到 server 的 443 端口。

2、服务端的配置

采用 HTTPS 协议的服务器必须要有一套数字证书,可以自己制作,也可以向组织申请,区别就是自己颁发的证书需要客户端验证通过,才可以继续访问,而使用受信任的公司申请的证书则不会弹出提示页面(startssl 就是个不错的选择,有 1 年的免费服务)。

3、传送证书

这个证书其实就是公钥,只是包含了很多信息,如证书的颁发机构,过期时间等等。

4、客户端解析证书

这部分工作是有客户端的TLS来完成的,首先会验证公钥是否有效,比如颁发机构,过期时间等等,如果发现异常,则会弹出一个警告框,提示证书存在问题。

如果证书没有问题,那么就生成一个随机值,然后用证书对该随机值进行加密,就好像上面说的,把随机值用锁头锁起来,这样除非有钥匙,不然看不到被锁住的内容。

5、传送加密信息

这部分传送的是用证书加密后的随机值,目的就是让服务端得到这个随机值,以后客户端和服务端的通信就可以通过这个随机值来进行加密解密了。

6、服务端解密信息

服务端用私钥解密后,得到了客户端传过来的随机值(私钥),然后把内容通过该值进行对称加密,所谓对称加密就是,将信息和私钥通过某种算法混合在一起,这样除非知道私钥,不然无法获取内容,而正好客户端和服务端都知道这个私钥,所以只要加密算法够彪悍,私钥够复杂,数据就够安全。

7、传输加密后的信息

这部分信息是服务段用私钥加密后的信息,可以在客户端被还原。

8、客户端解密信息

客户端用之前生成的私钥解密服务段传过来的信息,于是获取了解密后的内容,整个过程第三方即使监听到了数据,也束手无策

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值