网络10:关于http协议的requset 和 repose的结构

1.http request

1.1结构

request 报文的结构主要包括三部分:请求行、请求报头、请求正文

1.1.1 请求行

关于请求行中,一般有三个属性,第一个是Method,请求的方法,一般有2种,POST和GET

第二个是url地址,要请求目标的地址

第二个是请求的HTTP版本:一般是 HTTP1.0 HTTP1.1 HTTP1.2

1.1.2 请求报头

请求报头中大部分信息是键值对。

key:value key代表属性 value代表是什么属性

1.1.3 请求正文

请求正文就是请求的数据(有效载荷)

1.1.4 之间的关系

读取数据的时候是按行读取的,用 /r/n(回车换行符)来分割每一行,但是存储的时候是直接存储的,我们把 /r /n 当做字符,可以直接存储

1.2 怎样分离报头(请求行,请求报头)和有效载荷(请求正文)

每一行的结束都是 /r /n,我们用空行的方法

1.3 我们确保怎样读取完整的正文呢?

在报头中有一个属性,代表的是报文的长度,Content-Length:

2.http respose

respose 和request 结构大致相同,但是repose 的第一行是状态行,代表本次请求的状态

http version 代表的是请求的版本

状态码和状态码描述 代表的是请求的状态 ,例如:404 NOT FONUND

3.拓展

3.1请求和响应的过程图示

3.2 使用 request

bash 复制代码
[zxy@iZ2zedsl7yyx1pwqlzferiZ ~]$ telnet www.baidu.com 80
Trying 220.181.38.150...
Connected to www.baidu.com.
Escape character is '^]'.
^]
telnet> 
Get / HTTP/1.1

我们使用telnet 链接百度, 使用Get方法,获取 / 根目录 使用 HTTP1.1版本

结果如下:

bash 复制代码
HTTP/1.1 302 Found
Bdpagetype: 3
Content-Length: 154
Content-Type: text/html
Date: Mon, 02 Sep 2024 11:36:19 GMT
Location: https://www.baidu.com/search/error.html
Server: BWS/1.1
Set-Cookie: BDSVRTM=0; path=/
Traceid: 172527697903663388268371857954822945100
X-Ua-Compatible: IE=Edge,chrome=1
X-Xss-Protection: 1;mode=block

<html>
<head><title>302 Found</title></head>
<body bgcolor="white">
<center><h1>302 Found</h1></center>
<hr><center>nginx</center>
</body>
</html>

我们也可以使用其他软件来抓包(fiddler,postman)

这些软件的原理是充当中介,让他们发出请求,(梯子的原理)

相关推荐
想用offer打牌20 分钟前
一站式了解跨域问题
网络协议·面试·架构
伊玛目的门徒36 分钟前
HTTP SSE 流式响应处理:调用腾讯 智能应用开发平台ADP智能体的 API
python·网络协议·http·腾讯智能体·adp·智能应用开发平台
2501_9388101138 分钟前
动态IP的使用方法
网络·网络协议·tcp/ip
Neolnfra1 小时前
陇剑杯2021-wifi题目解析
网络·安全·web安全·网络安全·系统安全·密码学·csrf
一周困⁸天.1 小时前
K8S-CoreDNS组件
网络·kubernetes
无限大.1 小时前
为什么网站需要“域名“?——从 IP 地址到网址的演进
网络·网络协议·tcp/ip
sdszoe49221 小时前
思科DHCP服务1
网络·思科网络·dhcp服务基础
JANG10242 小时前
【Linux】进程
linux·网络·chrome
wha the fuck4042 小时前
(渗透脚本)TCP创建连接脚本----解题----极客大挑战2019HTTP
python·网络协议·tcp/ip·网络安全·脚本书写
濊繵2 小时前
Linux网络--网络层协议 IP
服务器·网络·tcp/ip