HTTP请求/响应机制原理
作者:互联网
1.1浏览器根据域名解析IP地址
浏览器根据访问的域名找到其IP地址。DNS查找过程如下:
1).浏览器缓存 :首先搜索浏览器自身的DNS缓存(缓存的时间比较短,大概只有1分钟,且只能容纳1000条缓存),看自身的缓存中是否是有域名对应的条目,而且没有过期,如果有且 没有过期则解析到此结束。
2).系统缓存:如果浏览器自身的缓存里面没有找到对应的条目,那么浏览器会搜索操作系统自身的DNS缓存,如果找到且没有过期则解析到此结束。
3).路由器缓存:如果系统缓存也没有找到,则会向路由器发送查询请求。
4).ISP(互联网服务提供商)DNS缓存:如果在路由器也没找到,最后要查的就是ISP缓存DNS的服务器。
1.2浏览器与WEB服务器建立一个TCP连接
TCP3次握手(详情请参照:https://blog.csdn.net/qq_39907229/article/details/83012709 )
1.3浏览器给WEB服务器发送一个HTTP请求
一个HTTP请求报文由请求行(request line)、请求头部(headers)、空行(blank line)和请求数据(request body)4个部分组成。
请求方法 空格 URL 空格 协议版本 回车符 换行符 === 请求行
头部字段名 : 值 回车符 换行符 ===
... === 请求头部
头部字段名 : 值 回车符 换行符 ===
回车符 换行符 === 空行
=== 请求数据
1.3.1请求行
请求行分为三个部分:请求方法、请求地址URL和HTTP协议版本,它们之间用空格分割。例如,GET /index.html HTTP/1.1
1).请求方法
HTTP/1.1定义发请求方法有8种:GET(完整请求一个资源)、POST(提交表单)、
PUT(上传文件)、DELETE(删除)、PATCH、HEAD(仅请求响应首部)、OPTIONS
(返回请求的资源所支持的方法)、TRACE(追求一个资源请求中间所经过的代理)
2).URL
URL:统一资源定位符,是一种资源位置的抽象唯一识别方法。
组成:<协议>://<主机>:<端口>/<路径> 默认是80,可以省略
3).协议版本
协议版本的格式为:HTTP/主版本号.次版本号,常用的有HTTP/1.0和HTTP/1.1
1.3.2请求头部
请求头部为报文添加了一些附加信息,由"名/值"对组成,每行一对,名和值直接
使用冒号分隔
请求头部的最后会是一个空行,表示请求头部结束
1.3.3请求数据
请求数据是在POST方法适用于用户填写表单的场景,与请求数据相关的最长使用
的请求头部是Content-Type和Content-Length
如:Content-Length:25
Content-Type:application/x-www-form-urlencoded
空行
username=aa&password=1234 请求数据
1.4服务器端响应HTTP请求,浏览器得到HTML代码
HTTP响应报文由状态行(status line)、相应头部(headers)、空行(blank line)
和响应数据(response body)4个部分组成
协议版本 空格 状态码 空格 状态描述 回车符 换行符 === 状态行
头部字段名 : 值 回车符 换行符 ===
... === 响应头部
头部字段名 : 值 回车符 换行符 ===
回车符 换行符 === 空行
=== 响应正文
1.5 浏览器解析HTML代码,并请求HTML代码中的资源
浏览器拿到HTML文件后,开始解析HTML代码,遇到静态资源时,就向服务器端去请求下载。
1.6 关闭TCP连接,浏览器对页面进行渲染呈现给用户
浏览器利用自己内部的工作机制,把请求到的静态资源和HTML代码进行渲染,呈现给用户。
参照来源: https://blog.csdn.net/ailunlee/article/details/90600174
标签:缓存,浏览器,请求,回车符,响应,头部,HTTP 来源: https://blog.csdn.net/weixin_43467066/article/details/114998798