HTTP与HTTPS的前尘往事

HTTP与HTTPS的前尘往事

码农世界 2024-05-19 后端 63 次浏览 0个评论

目录

一、HTTP 

工作原理

特点

请求方法

HTTP状态码

应用场景

二、HTTPS

工作原理

特点

应用场景

三、HTTP与HTTPS的关系

安全性

端口号

证书和密钥

握手过程

性能

使用场景

搜索引擎优化(SEO)

四、HTTPS存在的价值

原因


一、HTTP 

HTTP(Hypertext Transfer Protocol,超文本传输协议)是一个简单的请求-响应协议,它通常运行在TCP之上,并指定了客户端可能发送给服务器什么样的消息以及得到什么样的响应。

工作原理

客户端发起请求:客户端(通常是Web浏览器)向服务器发送HTTP请求。请求包括请求的方法(如GET、POST等)、要访问的资源的URL地址、HTTP协议版本等信息。

服务器响应请求:服务器收到客户端的请求后,根据请求的内容进行处理,并通过TCP连接将生成的HTTP响应包发送回客户端。

特点

无连接:HTTP协议不需要在客户端和服务器之间建立持久的连接,每次请求和响应完成后连接就会关闭,这减少了网络开销。

无状态:HTTP协议对事务的处理没有记忆能力,每次请求都需要提供完整的请求信息。

面向对象:HTTP协议可以传输任何类型的数据对象,包括文本、图片、音频、视频等。

无阻塞:HTTP协议不会限制客户端的请求数量和大小,使得服务器可以处理大量的请求。

可缓存:HTTP协议允许客户端缓存服务器响应的内容,以提高响应速度和减少网络流量。

请求方法

GET:表示请求指定的页面信息,并返回实体内容。

POST:表示向指定资源提交数据,数据包含在请求头中,有可能导致新的资源建立或原有资源修改。

HEAD:类似于GET,只不过返回的响应体中没有具体内容,只有报文头,用于获取报文头。

PUT:从客户端向服务器传送的数据取代指定的内容,即向指定的位置上传最新的内容。

PATCH:对PUT方法的补充,用来对已知资源进行局部更新。

DELETE:请求服务器删除Request-URL所标识的资源。

OPTIONS:返回服务器针对特殊资源所支持的HTML请求方式或允许客户端查看服务器的性能。

HTTP状态码

HTTP状态码是用以表示网页服务器超文本传输协议响应状态的3位数字代码。它由RFC 2616规范定义,并得到其他相关规范的扩展。所有状态码的第一个数字代表了响应的五种状态之一,包括消息、成功、重定向、客户端错误和服务器错误。

1xx(信息性状态码):表示请求已经接收,继续处理。常见的状态码有:100 Continue:客户端应当继续发送请求。这个临时响应是用来通知客户端它的部分请求已经被服务器接收,且仍未被拒绝。 101 Switching Protocols:服务器已经理解了客户端的请求,并将通过Upgrade消息头通知客户端采用不同的协议来完成这个请求。 102 Processing:由WebDAV(RFC 2518)扩展的状态码,代表处理将被继续执行。

2xx(成功状态码):表示请求已经被成功接收、理解、并处理。常见的状态码有:200 OK:请求已成功,请求所希望的响应头或数据体将随此响应返回。 201 Created:请求已经被实现,而且有一个新的资源已经依据请求的需要而建立,且其URI已经随Location头信息返回。 202 Accepted:服务器已接受请求,但尚未处理。

3xx(重定向状态码):表示请求需要进一步操作,以完成请求。常见的状态码有:301 Moved Permanently:请求的网页已永久移动到新位置。 302 Found:临时移动。 303 See Other:建议客户访问其他URL或访问方式。 304 Not Modified:自从上次请求后,请求的网页未修改过。

4xx(客户端错误状态码):表示客户端的请求有问题。常见的状态码有:400 Bad Request:服务器无法理解请求的格式,客户端不应当尝试再次使用相同的内容发起请求。 404 Not Found:服务器无法根据客户端的请求找到资源(网页)。

5xx(服务器错误状态码):表示服务器处理请求时出现了错误。常见的状态码有:500 Internal Server Error:服务器遇到了一个未曾预料的情况,导致了它无法完成对请求的处理。 503 Service Unavailable:由于临时的服务器维护或者过载,服务器当前无法处理请求。

应用场景

Web应用:HTTP最广泛的应用就是Web应用程序。无论是桌面端的浏览器还是移动端的应用程序,HTTP都是数据的传输协议。HTTP通过传输HTML、CSS、JavaScript等静态资源文件和API接口等动态资源文件,提供支撑服务器响应用户请求的基础。

物联网:物联网应用中的传感器和设备可以通过HTTP协议与云服务器进行数据交互。

移动应用:HTTP协议在移动应用程序中也扮演着重要的角色。移动应用通常都需要与服务器进行数据交互,比如获取社交网络应用的最新动态,或者是获得在线商城的商品信息。

二、HTTPS

HTTPS(全称:Hypertext Transfer Protocol Secure)是一种在HTTP基础上加入了安全层(SSL/TLS)的协议,它主要用于在安全的通信通道上传输数据。

工作原理

HTTPS在HTTP的基础上,通过传输加密和身份认证保证了传输过程的安全性。具体来说,HTTPS在HTTP与TCP之间加入了一个加密/身份验证层(SSL或TLS),这个系统提供了身份验证与加密通讯方法。

当客户端(如Web浏览器)与服务器建立连接时,会进行SSL/TLS握手,以协商加密算法、交换密钥等。然后,客户端和服务器之间的通信数据都会被加密传输,确保数据的安全性和完整性。

特点

安全性:通过SSL/TLS协议对数据进行加密和身份验证,确保数据在传输过程中的保密性和完整性。加密保护了敏感数据的机密性,防止被第三方截获和窃取;身份验证防止了中间人攻击,确保了通信双方的身份可信。

可信性:HTTPS使用证书来验证服务器的身份。证书由可信任的证书颁发机构(CA)签发,包含了服务器的公钥和颁发机构的数字签名。客户端在与服务器建立连接时会验证证书的真实性和合法性,确保通信双方的身份可信。

SEO优化:搜索引擎将HTTPS作为网站排名的一个重要指标。使用HTTPS可以提高网站在搜索引擎中的排名,增加网站的曝光度和流量。

安全的Cookie传输:在HTTPS连接中,所有的Cookie都会通过加密的方式传输,防止被窃取和篡改。这对于保护用户的登录凭据和敏感信息非常重要。

用户信任度提升:使用HTTPS协议可以提升用户对网站的信任度。用户可以通过浏览器地址栏中的HTTPS安全锁或绿色地址栏来识别网站是否使用了HTTPS。

应用场景

在线购物:用户在购物网站上输入银行卡号、密码等敏感信息时,HTTPS可以确保这些信息的安全传输,防止被黑客窃取。

网上银行:网上银行涉及到用户的账户信息和资金安全,因此必须使用HTTPS协议来保护用户的敏感信息。

登录和注册页面:对于任何需要用户登录的网站,都需要通过HTTPS来保护用户输入的用户名和密码等敏感信息。

邮件系统:电子邮件可以包含私人和机密信息,因此也需要加密传输。使用HTTPS可以确保邮件得到加密,并且只能被预定的收件人读取。

三、HTTP与HTTPS的关系

HTTP(Hypertext Transfer Protocol)和HTTPS(Hypertext Transfer Protocol Secure)是用于在Web上传输数据的两种协议。

安全性

HTTP:是一个非安全的协议,这意味着在HTTP上传输的数据(如网页内容、用户凭证等)是以明文形式发送的,因此容易受到中间人攻击(Man-in-the-Middle Attack, MITM)。 HTTPS:是一个安全的协议,它在HTTP的基础上增加了一层安全层(通常是通过SSL/TLS协议实现的)。这意味着在HTTPS上传输的数据是加密的,从而提供了数据完整性和身份认证。

端口号

HTTP:通常使用80端口进行通信。

HTTPS:通常使用443端口进行通信。

证书和密钥

HTTPS要求服务器拥有一个由受信任的证书颁发机构(Certificate Authority, CA)颁发的SSL证书。这个证书包含了服务器的公钥和一些其他信息,用于在客户端和服务器之间建立安全的加密连接。

客户端和服务器使用公钥和私钥对进行加密和解密操作,确保数据在传输过程中的安全性。

握手过程

当客户端尝试通过HTTPS与服务器建立连接时,会经历一个称为“握手”的过程。在这个过程中,客户端和服务器会交换信息以验证对方的身份,并协商用于加密通信的加密算法和密钥。

性能

由于HTTPS需要进行额外的加密和解密操作,以及证书验证等步骤,因此相对于HTTP来说,HTTPS的性能通常会稍差一些。然而,随着硬件和软件的不断优化,HTTPS的性能差距正在逐渐缩小。

使用场景

HTTP通常用于不需要加密传输的场景,如静态资源的下载、非敏感数据的传输等。 HTTPS则广泛用于需要保护数据完整性和隐私性的场景,如在线银行、电子商务、登录页面等。

搜索引擎优化(SEO)

使用HTTPS的网站在搜索引擎排名中可能会获得一些优势。Google等搜索引擎已经将HTTPS视为排名因素之一,并鼓励网站使用HTTPS来提高安全性。

四、HTTPS存在的价值

在这个网络普及的年代,网络中存储在着我们大量的个人信息,如身份证号码、联系方式、银行账号等。这些信息一旦被盗取,就会危机我们自身的安全,甚至人身安全。但是TCP/IP协议作为网络发展的一个基础,是有相对的脆弱性。所以对于基于TCP的HTTP而言就不是那么的安全。

原因

TCP/IP数据链路层安全性缺陷:数据链路层介于物理层和网络层之间,在物理层提供服务的基础上向网络层提供服务,其最基本的服务是将源自网络层来的数据可靠的传输到相邻节点的目标机网络层。数据链路层上常见的攻击方式是嗅探,嗅探是在共享的网络信道上,利用网络接口卡接收数据链路层中传输的数据包。

协议缺乏传输质量保障和故障发现功能:信道通信行为会随着时间和地理位置变化而变化,因此TCP/IP缺乏网络自适应性。发生在无线上网包的丢失,TCP认为是拥塞引起的,但实际上可能是由于信道错误或网络延迟而导致的。

协议缺乏对终端身份的安全识别能力:TCP协议的3次握手中协议缺乏对终端身份的安全识别能力导致报文在传输中遇到的问题概率增加,IP欺骗就是3次握手导致的网络问题。

转载请注明来自码农世界,本文标题:《HTTP与HTTPS的前尘往事》

百度分享代码,如果开启HTTPS请参考李洋个人博客
每一天,每一秒,你所做的决定都会改变你的人生!

发表评论

快捷回复:

评论列表 (暂无评论,63人围观)参与讨论

还没有评论,来说两句吧...

Top