网络编程HTTP协议进化史

2023-12-06 03:28

本文主要是介绍网络编程HTTP协议进化史,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、Http报文格式

具有约定格式的数据块

请求报文 request

  • 状态行:本次请求的请求方式(post get)资源路径url  http 协议的版本号,中间用空格划分

本次请求的请求方式(post get)资源路径url  http 协议的版本号,中间用空格划分

  • 请求头:requestHeaders,用户代理信息cookie信息,客户端所接受的数据编码格式信息
  • 请求正文:requestBody 数据
  • post中以key-value 的形式存储
  • get中这个部分是没有的

红框:固定空白行,HTTP约定了数据在传输的时候请求头和请求正文必须空出一行,用来判定请求头的内容是否被读取完了

当客户端发送请求之后根据请求头中的状态行是post还是get做出响应,然后把结果返回给客户端,

响应报文 response 

  • 状态行:http协议以及版本,状态码,statecode 中间用空格隔开
  • 响应头:发送响应的时间,回应数据的格式,数据的长度等
  • 响应正文:响应具体的数据,responseBody 

由固定的传输格式形成了http协议,http是基于TCP传输的应用层协议,http只是约定了数据的格式,传输还是要靠TCP

二、HTTP协议进化史

Http1.0

        Http1.0版本有个致命的问题,TCP的链接无法复用,每次建立一个Http 请求,都需要建立一个TCP链接,TCP链接是需要3次握手的

Http1.1

        Http1.1为了解决这个问题约定了47种headers,其中包括了Connection:keep-alive 允许TCP链接数据发送完了之后继续存活一段时间,允许一段时间内继续复用这个链接,多次请求共用这次链接,具体复用时间长短由服务器控制,一般在15s 左右,这个keep-alive相当于线程池的keepAliveTime 当线程工作完成之后,线程存活一段时间,从而让发出的请求尽早的得到响应,跟这里同一个道理;
        除此之外还引入了更多的缓存策略,比如Entity tag, lf-Unmodified-Since, If-Match,cache-control。所以在这个版本可以更加灵活的控制缓存数据;
        还引入了range 这个headers 字段,允许只请求服务器资源的某一个部分,来达到带宽优化的问题,当客户端有了一部分资源之后只需要向服务器请求剩下的资源即可,这就是文件断点续传的基础
        Http1.1是对Http1.0功能的扩展以及对已知问题的优化
存在的问题:

  • *对于不同域名数据传输依旧是需要重新建立新的TCP连接,或者同一个域名在15s以后无法复用,断开了,接下来的请求也是需要重新创建连接
  • Http所有传输内容都是明文,http无法验证对方身份,无法保证数据的安全性
  • http请求报文当中header部分携带的数据内容过大,比如cookie 数据,这样在一定程度上增加了传输的成本

HTTPS

        它的网络模型就是HTTP+SSL

也就是在http上面套了一层可以处理加密信息的模块,服务端和客户端的传输都可以通过SSL 来检测和校验

SSL 如何加密跟解密的?

  1. 客户端向服务器端发送请求,此时客户端还会把它所支持加密的协议算法种类以及版本发送给服务端,服务端接收到请求之后会从客户端支持的加密协议中选择一个合适的,并且向客户端确认,之后的会话通过这种方式来加密
  2. 于此同时还会把服务器的公钥证书发送给客户端,这个证书包含了公钥,颁发机构,过期时间等一些信息,采用了https协议的服务器,必须有一套数字证书的,这套证书可以自己制作,也可以向组织申请
  3. 客户端在收到这个证书之后进行有效的验证,这个验证是由SSL 来完成的,首先验证证书的公钥是否有效,然后颁发机构,证书的过期时间。如果证书有异常,就会弹出一个安全警告。如果证书有效,此时就会生成一个随机数,也就是本次会话密钥,然后用公钥来加密,为了安全,不能让第三方知道本次会话密钥,当服务端通过数字证书的私钥才能够去解密,才能拿到本次会话的数据内容
  4. 把加密后的会话密钥传送给服务端
  5. 服务端使用私钥来解密会话密钥,服务端拿到会话密钥之后,就将想给返回客户端的response 进行加密
  6. 将加密后的response返回给客户端
  7. 客户端通过之前生成的会话密钥进行解密

存在的问题:

        由于加密导致传输慢,这个可以接受,毕竟互联网安全才是第一位的

免费签发证书机构 Let’a Encrypt 

SPDY 

        基于TCP的应用层协议
        目标是为了优化http协议的性能,通过数据压缩以及多路复用,以及请求优先级等多种技术缩短接口的等待时间,并且提高了数据传输的安全性,是对http协议的增强,综合了http和https
特性:

  • 多路复用TCP通道,减少TCP连接握手的时间,降低http的高延时,提供了网络的响应速度
  • 允许请求设置优先级,重要的请求可以得到优先的响应,比如在开发线程池组件的时候给每个任务设置优先级
  • 对http请求报文的headers数据进行压缩,http1.0和http1.1可能出现重复和冗余的数据并且在1.1的时候只能压缩body的数据,spdy 可以对headers 进行强有力的压缩,能够在一定程度上提高传输的效率
  • 同样基于SSL的安全传输,也能提高数据传输的可靠性

使用SPDY 的大厂:阿里,同时在使用https

缺点:

        只能使用文本格式的数据传输

HTTP 2.0

在SPDY 基础上开发了2.0,对http协议的又一次加强升级

  • 对数据报文重新定义了数据传输格式,摒弃了文本传输,采用了二进制格式,文本格式在各个平台的多样性,二进制只有0和1的组合。变成了一个个的数据帧,这些数据帧可以在不同的通道中交错的发送
  • TCP 通道多路复用
  • 支持降级成明文传输,SPDY 强制使用SSL/TLS
  • 都对header 部分进行了压缩,http2.0采用HPACK专有算法进行压缩消息头

        增加了二进制分帧层,在分帧层上面http2.0会将所有的传输信息,分为更小单位的消息体,称为帧,Frame ,http1.1 1.0的消息头都会被封装到header frame 里面,而body部分会被封装到Date Frame 里面。http2.0可以在共享TCP链接基础上同时的发送请求和响应,请求发送的时候会将数据帧交错的发送出去,原本一种请求在一个TCP 链接里面,在http2.0里面原本的数据被拆分成多个数据帧,这些数据帧可以在不同的TCP通道中交错的发送,通过这种技术http2.0性能得到极大的提高

http2.0速度的极大提升主要是因为数据编码格式的重新定义,多路复用,还有请求头数据的压缩
http2.0使用的大厂 阿里 腾讯 百度

Http3.0(还未商用)

        最大改变使用UDP 作为传输协议

  • 由于TCP 是面向连接的,每次连接需要3次握手,因此http存在高延迟的问题,UDP是无连接的,不需要三次握手
  • 优化了失败重传
  • 流量控制

在Android P上已经禁止了明文传输,在网络优化时可以采用SPDY 和http2.0或者headers 字段做断点续创缓存控制,链接保持以提高网络的响应速度

这篇关于网络编程HTTP协议进化史的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

如何使用Docker部署FTP和Nginx并通过HTTP访问FTP里的文件

《如何使用Docker部署FTP和Nginx并通过HTTP访问FTP里的文件》本文介绍了如何使用Docker部署FTP服务器和Nginx,并通过HTTP访问FTP中的文件,通过将FTP数据目录挂载到N... 目录docker部署FTP和Nginx并通过HTTP访问FTP里的文件1. 部署 FTP 服务器 (

Qt实现发送HTTP请求的示例详解

《Qt实现发送HTTP请求的示例详解》这篇文章主要为大家详细介绍了如何通过Qt实现发送HTTP请求,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、添加network模块2、包含改头文件3、创建网络访问管理器4、创建接口5、创建网络请求对象6、创建一个回复对

springMVC返回Http响应的实现

《springMVC返回Http响应的实现》本文主要介绍了在SpringBoot中使用@Controller、@ResponseBody和@RestController注解进行HTTP响应返回的方法,... 目录一、返回页面二、@Controller和@ResponseBody与RestController

Qt 中集成mqtt协议的使用方法

《Qt中集成mqtt协议的使用方法》文章介绍了如何在工程中引入qmqtt库,并通过声明一个单例类来暴露订阅到的主题数据,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一,引入qmqtt 库二,使用一,引入qmqtt 库我是将整个头文件/源文件都添加到了工程中进行编译,这样 跨平台

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为

C#多线程编程中导致死锁的常见陷阱和避免方法

《C#多线程编程中导致死锁的常见陷阱和避免方法》在C#多线程编程中,死锁(Deadlock)是一种常见的、令人头疼的错误,死锁通常发生在多个线程试图获取多个资源的锁时,导致相互等待对方释放资源,最终形... 目录引言1. 什么是死锁?死锁的典型条件:2. 导致死锁的常见原因2.1 锁的顺序问题错误示例:不同

PyCharm接入DeepSeek实现AI编程的操作流程

《PyCharm接入DeepSeek实现AI编程的操作流程》DeepSeek是一家专注于人工智能技术研发的公司,致力于开发高性能、低成本的AI模型,接下来,我们把DeepSeek接入到PyCharm中... 目录引言效果演示创建API key在PyCharm中下载Continue插件配置Continue引言

详解Java如何向http/https接口发出请求

《详解Java如何向http/https接口发出请求》这篇文章主要为大家详细介绍了Java如何实现向http/https接口发出请求,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 用Java发送web请求所用到的包都在java.net下,在具体使用时可以用如下代码,你可以把它封装成一

SSID究竟是什么? WiFi网络名称及工作方式解析

《SSID究竟是什么?WiFi网络名称及工作方式解析》SID可以看作是无线网络的名称,类似于有线网络中的网络名称或者路由器的名称,在无线网络中,设备通过SSID来识别和连接到特定的无线网络... 当提到 Wi-Fi 网络时,就避不开「SSID」这个术语。简单来说,SSID 就是 Wi-Fi 网络的名称。比如

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五