Wireshark笔记-DNS流程与数据包解析

知识点

DNS(域名系统)是互联网的域名→IP 翻译器:它将人类易记的域名(如 www.qq.com)映射为机器识别的 IP 地址,让设备找到目标服务器。通过根、顶级、权威服务器组成的层级架构,以递归 / 迭代查询完成解析,是浏览器访问网站、App 连接服务的核心基石,让用户无需记忆复杂 IP,只需输入域名即可联网。

DNS 交互流程:客户端向本地 DNS 发域名查询,本地 DNS 先查缓存(命中则直接返 IP);未命中时,递归模式下委托上游服务器代查(根→顶级→权威服务器逐层解析),迭代模式下自身依次查询。权威服务器返回 IP 后,本地 DNS 缓存并转发给客户端,完成域名→IP 映射。

分析过程

打开Wirshark抓包后。使用cmd程序ping下www.qq.com,如下图所示。

可见Wirshark抓到4个包,现在来逐个分析下。

在上图为第一个dns包,Wirshark已经做了很详细的解读了,从中可以得到的信息。

① 访问DNS的服务器为8.8.8.8,端口为53(DNS的默认端口在标准场景下是53)

② DNS是基于UDP(User Datagram Protocol)的。

③ DNS(Domain Name System)查询相关的报文信息:

A. 事务 ID:0x1287(唯一标识,用于匹配响应)。

B. 标志位:QR=0(查询)、RD=1(请求递归解析,依赖服务器递归查)、OPCODE=0(标准查询)。

C. 问题数:1(仅 1 个查询问题),资源记录数:0(无响应数据)。

D. 问题段(Question):域名:www.qq.com(查询的目标域名)。

E. 问题段(Question):类型:A(请求 IPv4 地址),类:IN(互联网,默认)。

与包8对应的是包9,先来看看包9。

从中可以得到的信息:

① 事务 ID:0x1287(与包 7 的 ID 一致,关联请求)。

② 标志位:QR=1(响应)、AA=1(权威应答,服务器是域名的权威源)、RCODE=0(解析成功)。

③ 问题数:1(与请求一致),回答数:3(含 1 条 CNAME + 2 条 A 记录,与后面的3条能对应起来)。

④ 回答段(Answer):第一条(CNAME 记录):

⑤ 回答段(Answer):域名:www.qq.com

⑥ 回答段(Answer):类型:CNAME(别名类型,指向 ins-r23tsuuf.ias.tencent-cloud.net

⑦ 回答段(Answer):TTL:缓存时间

⑧ 后两条(A 记录):域名:ins-r23tsuuf.ias.tencent-cloud.net(CNAME 指向的真实域名)

⑨ 后两条(A 记录):类型:A,IP:116.128.170.212、58.246.163.58(最终 IPv4 地址)

第9个知识点比较重要,因为DNS劫持,DNS负载均衡等,这个安全问题和负载问题就是修改了这个地方,后期将会有文章分别说明这两块内容。

包8和包10是IPV6的版本,原理方面和包7、包9是差不多一致的,在此不在详细说明,给出对应的截图。

客户端发送查询请求(包8)

DNS回响应(包10)

相关推荐
东京老树根2 小时前
SAP学习笔记 - BTP CAP开发06 - Customize Criticality,Map Page,Value help
笔记·学习
AM越.3 小时前
助睿:!!零代码解决!!订单利润分流数据加工o(* ̄▽ ̄*)ブ
数据仓库·笔记·etl·助睿
魔都大虾4 小时前
旧时光里面有那些情话句子 什么比较热门
笔记
Java成神之路-4 小时前
【算法刷题笔记】全题型导航目录
笔记·算法
zhangrelay4 小时前
云课实践速通系列-基础篇汇总-必修-通识基础和专业基础-2026--工科--自动化、电气、机器人、测控等
linux·笔记·单片机·学习·ubuntu·机器人·自动化
05候补工程师4 小时前
【编译原理】自顶向下语法分析深度解析:从 LL(1) 文法判定、改写到预测分析表
经验分享·笔记·考研·自然语言处理
ErizJ6 小时前
Linux|学习笔记
linux·笔记·学习
wanghanjiett7 小时前
笔记:ESP32驱动SimpleFOC成功(基于Espressif-IDE)
笔记·esp32·foc
大邳草民7 小时前
Python 爬虫:从 HTTP 请求到接口分析
笔记·爬虫·python
南湖渔歌7 小时前
【成功实践版】workbuddy_把多张图片转成完整Markdown笔记
人工智能·笔记·workbuddy