http报头解析

http报文

http报文主要有两类是常见的,第一类是请求报文,第二类是响应报文,每个报头除了第一行,都是采用键值对进行传输数据,请求报文的第一行主要包括http方法(GET,PUT, POST),请求资源的url,http协议版本。响应报文第一行是状态行,它包括http协议版本,状态码(200表示成功,404表示没有找到等),状态消息(如OK,Not found等)

请求报文一般是客户端发送给服务端的,表示要请求的资源,响应报文一般是服务端给客户端的,返回对应的资源。

请求报文

Host:指定请求的服务器的域名和端口号。

User-Agent:包含了发出请求的浏览器类型、版本和操作系统信息。

Accept:浏览器能够处理的媒体类型。

Accept-Language:浏览器偏好的语言。

Accept-Encoding:浏览器能够处理的压缩算法。

Connection:管理持久连接,如 keep-alive。

Cookie:存储在用户本地的会话信息。

Authorization:用于HTTP认证的凭证信息。

Content-Length:请求正文的长度。

Content-Type:请求正文的媒体类型。

但是需要注意的是,这些字段不一定都是全部都有的,发送方会根据自己的需求进行取舍,行与行之间是用过"\r\n"进行隔开,而报头和正文是通过"/r/n/r/n"就是两行换行进行隔离

这就是一个经典的例子

下面是几个请求方法不同

  1. GET

    • 用于请求从服务器检索特定资源。
    • 应该只用于获取数据,不应产生服务器上的状态变化。
    • 幂等的,意味着多次执行相同的GET请求应该得到相同的结果,且不会影响资源的状态。
    • 通常用于数据查询。
  2. POST

    • 用于向服务器提交数据进行处理请求,例如提交表单或上传文件。
    • 可以导致新资源的创建或现有资源的修改。
    • 不是幂等的,因为多次执行相同的POST请求可能会导致资源状态的不同变化。
    • 通常用于创建新资源。
  3. PUT

    • 用于上传文件或发送数据给服务器以创建新的资源或替换已存在的资源。
    • 如果资源不存在,则创建资源;如果资源已存在,则替换资源。
    • 幂等的,多次执行相同的PUT请求应该得到相同的结果。
    • 通常用于更新现有资源。

响应报文

Content-Type:响应正文的媒体类型。

Content-Length:响应正文的长度。

Set-Cookie:服务器发送给客户端的会话信息。

Cache-Control:控制响应的缓存行为。

Expires:响应过期的时间。

Last-Modified:资源最后被修改的时间。

ETag:资源的特定版本标识。

Server:服务器软件名称。

Location:用于重定向的URL。

WWW-Authenticate:用于HTTP认证的挑战信息。

但是需要注意的是,这些字段不一定都是全部都有的,发送方会根据自己的需求进行取舍,行与行之间是用过"\r\n"进行隔开,而报头和正文是通过"/r/n/r/n"就是两行换行进行隔离,其中Content-Length是不包括报头长度

相关推荐
Christal_pyy11 分钟前
树莓派4基于Debian GNU/Linux 12 (Bookworm)添加多个静态ipv4网络
linux·网络·debian
csbDD1 小时前
2025年网络安全(黑客技术)三个月自学手册
linux·网络·python·安全·web安全
s_fox_2 小时前
nginx ngx_http_module(7) 指令详解
运维·nginx·http
荔枝荷包蛋6662 小时前
【Linux】HTTP:Cookie 和 Session 详解
网络·网络协议·http
EasyNVR2 小时前
EasyRTC智能硬件:实时畅联、沉浸互动、消音护航
运维·服务器·网络·安全·音视频·webrtc·p2p
CAir22 小时前
HTTP SSE 实现
http·libhv·sse
劉煥平CHN2 小时前
RabbitMQ的脑裂(网络分区)问题
网络·分布式·rabbitmq
阿湯哥3 小时前
越权漏洞及其修复方法
网络·安全·web安全
遥遥远方 近在咫尺3 小时前
HTTPS原理
网络协议·https
s_fox_3 小时前
nginx ngx_http_module(9) 指令详解
运维·nginx·http