HTTP 协议的基本格式和 fiddler 的用法

HTTP协议格式

HTTP是⼀个⽂本格式的协议.可以通过Chrome开发者⼯具或者Fiddler抓包,分析HTTP请求/响应的细节.

抓包工具的使用

以Fiddler为例.

• 左侧窗⼝显⽰了所有的HTTP请求/响应,可以选中某个请求查看详情.

• 右侧上⽅显⽰了HTTP请求的报⽂内容.(切换到Raw标签⻚可以看到详细的数据格式)

• 右侧下⽅显⽰了HTTP响应的报⽂内容.(切换到Raw标签⻚可以看到详细的数据格式)

• 请求和响应的详细数据,可以通过右下⻆的View in Notepad 通过记事本打开.

抓包工具的原理

Fiddler相当于⼀个"代理".

浏览器访问sogou.com时,就会把HTTP请求先发给Fiddler,Fiddler再把请求转发给sogou的服务 器.当sogou服务器返回数据时,Fiddler拿到返回数据,再把数据交给浏览器.

因此Fiddler对于浏览器和sogou服务器之间交互的数据细节,都是⾮常清楚的.

抓包结果

以下是⼀个HTTP请求/响应的抓包结果.

HTTP请求

• ⾸⾏:[⽅法]+[url]+[版本]

• Header:请求的属性,冒号分割的键值对;每组属性之间使⽤\n分隔;遇到空⾏表⽰Header部分结束

• Body:空⾏后⾯的内容都是Body.Body允许为空字符串.如果Body存在,则在Header中会有⼀个 Content-Length属性来标识Body的⻓度;

HTTP响应

• ⾸⾏:[版本号]+[状态码]+[状态码解释]

• Header:请求的属性,冒号分割的键值对;每组属性之间使⽤\n分隔;遇到空⾏表⽰Header部分结束

• Body:空⾏后⾯的内容都是Body.Body允许为空字符串.如果Body存在,则在Header中会有⼀个Content-Length属性来标识Body的⻓度;如果服务器返回了⼀个html⻚⾯,那么html⻚⾯内容就是在body中.

协议格式总结

一、请求格式

  1. 请求行
  • 包含请求方法(如 GET、POST、PUT 等)、请求的资源路径和 HTTP 版本。例如:"GET /index.html HTTP/1.1"。
  1. 请求头
  • 由一系列键值对组成,如"Host"表示请求的主机名,"User-Agent"表示发出请求的客户端信息等。

  • 每个请求头占一行,格式为"头字段名: 值"。

  1. 空行
  • 用于分隔请求头和请求体。
  1. 请求体
  • 对于某些请求方法(如 POST),会包含要提交的数据。

二、响应格式

  1. 状态行
  • 包含 HTTP 版本、状态码和状态描述。例如:"HTTP/1.1 200 OK"。
  1. 响应头
  • 与请求头类似,也是一系列键值对,如"Content-Type"表示响应内容的类型,"Content-Length"表示响应内容的长度等。
  1. 空行
  • 分隔响应头和响应体。
  1. 响应体
  • 服务器返回的具体内容,如 HTML 页面、JSON 数据等。
相关推荐
寂寞旅行2 小时前
解决摄像头/麦克风 在HTTP环境下的调用问题
网络·网络协议·http
爱学习的程序媛2 小时前
《图解HTTP》核心知识点梳理
网络·网络协议·http·https
老蒋新思维4 小时前
创客匠人 2025 全球创始人 IP+AI 万人高峰论坛:AI 赋能下知识变现与 IP 变现的实践沉淀与行业启示
大数据·人工智能·网络协议·tcp/ip·重构·创始人ip·创客匠人
游戏开发爱好者84 小时前
Charles 抓不到包怎么办?从 HTTPS 代理排错到底层数据流补抓的完整解决方案
网络协议·http·ios·小程序·https·uni-app·iphone
dragoooon346 小时前
[Linux网络基础——Lesson6.「HTTPS」]
网络·网络协议·https
2301_796923996 小时前
Nginx HTTPS服务搭建实验文档
网络·网络协议·ssl
apihz10 小时前
批量获取3位未注册短域名免费API接口每日更新
android·服务器·网络·网络协议·tcp/ip
北京耐用通信10 小时前
传感器“断联”拖垮产线?耐达讯自动化网关让Ethernet IP转CCLink秒通!
人工智能·科技·物联网·网络协议·自动化
Maryfang1329189155111 小时前
RTL8306MB的国产P2P替代方案用JL5106C的可行性分析
网络·网络协议·p2p
白菜__12 小时前
去哪儿小程序逆向分析(酒店)
前端·javascript·爬虫·网络协议·小程序·node.js