一、DNS报文结构
DNS报文采用大端字节序,由DNS报头与DNS正文组成。
data:image/s3,"s3://crabby-images/2e2b7/2e2b7107c48586cbf7dc6e92d0324586775ceb90" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
DNS报头定长12个字节,由
transaction ID 2个字节
+ flags 2个字节
+questions 2个字节 查询段中的条目数
+answers RRs 2个字节 应答段中的资源记录数
+authority RRs 2个字节 授权段中的资源记录数
+additional RRs 2个字节 附加段中的资源记录数
组成。
其中flags对应的术语:
QR query/response 1位 0表示query 1表示response
OPCODE 4位 值为0表示标准查询,值为1表示逆向查询,值为2表示查询服务器状态,值为3保留,值为4表示通知,值为5表示更新报文,值6~15的留为新增操作用
AA 是否要求授权,在响应中有效
TC 是否截断
RD 是否期望递归
RA 是否递归可用
Z 保留位
RCODE 响应码4位:值0表示没有错误;1表示格式错误;2表示服务器故障;3表示名字错误,仅对来自权威服务器的响应有意义,表示查询中引用的域名不存在;4表示没有实现;5表示拒绝;6-15保留将来使用
data:image/s3,"s3://crabby-images/cfd6c/cfd6cdbc037b930b758076842c0662e8950e4a3c" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
data:image/s3,"s3://crabby-images/d1b8b/d1b8bce7cc23ea49455c117c5409356e26b22f11" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
data:image/s3,"s3://crabby-images/fb1c3/fb1c3032a3c0502149aadeca9fd52827cba974cd" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
data:image/s3,"s3://crabby-images/16ee1/16ee1bbecc58197f94168e73ecd9b9184c9a3555" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
DNS正文包括
Question查询段、Answer应答段、Authority授权段、Additional附加段。
例如:对smtp.aol.com进行域名查询data:image/s3,"s3://crabby-images/331b5/331b5e490bf5d2b900efd22b9690039ec9e719e3" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
Question查询段包括
qname 变长,以\0x00结尾
+ qtype 2个字节
+ qclass 2个字节
data:image/s3,"s3://crabby-images/a53c8/a53c8dd24e2614d65f7b0947619926190f197d1a" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
data:image/s3,"s3://crabby-images/3bc01/3bc010606a51bc2cac8b3650efdbdfae466b5048" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
data:image/s3,"s3://crabby-images/38b4d/38b4de8da30fe3283c2377468e5b478c364bbb6f" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
0x0010 (16) 表示TXT,e.x. cujo.movie.edu. IN TXT “Location: machine room dog house"
0x000f (15) 表示MX, e.x. ora.com IN MX 0 ora.ora.com.
IN MX 10 ruby.ora.com
IN MX 10 opal.ora.com
0x001d (29)表示LOC location information,
0x000c (12) 表示PTR domain name pointer,e.x. 1.249.249.192.in-addr.arpa. IN PTR wormhole.movie.edu.
0x000d (13)表示 HINFO host information, e.x. grizzly.movie.edu. IN HINFO VAX-11/780 UNIX
0x0001 (1) 表示A (host address) e.x. localhost.movie.edu. IN A 127.0.0.1
0x001c (28)表示AAAA (IPv6 address)
0x0005 (5) 表示CNAME ,e.x. wh.movie.edu. IN CNAME wormhole.movie.edu.
0x00ff (255) 表示 *(A request for all records the server/cache has available),
0x002 (2) 表示NS(authoritative name server),e.x. movie.edu. IN NS terminator.movie.edu
0x0021 (33)表示SRV(server selection))
0x0006 (6) 表示SOA
name 2个字节 域名重复出现的时候采用消息压缩。头2位都是11,用于与标识区区别,后14位表示偏移量
+ type 2个字节
+ class 2个字节
+ time to live 4个字节
+ data length 2个字节 ,前2位必须是00,后面6位用于计算长度
+ data 变长
data:image/s3,"s3://crabby-images/1e92c/1e92cb0b2f14a9cddc143c73c5ea985be3a5c86e" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
data:image/s3,"s3://crabby-images/c5159/c51598a60c6f3f2afd2fa482845ee4c134630121" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
DNS数据格式
1. 2个字节整型
2. 4个字节整型
3. 域名
data:image/s3,"s3://crabby-images/28476/28476f16c34981eb1faf8e00f750f31b4093227b" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
4.字符串
data:image/s3,"s3://crabby-images/cf92e/cf92ea159742b15a7ef50536de7f76ee52f55941" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
1. txt类型 可任意填写,可为空。一般做一些验证记录时会使用此项,如:做SPF(反垃圾邮件)记录
data:image/s3,"s3://crabby-images/2ccca/2ccca864e5c97e280944772b1138af84ae0d4221" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
name 2个字节 域名重复出现的时候采用消息压缩。头2位都是11,用于与标识区区别,后14位表示偏移量
以0xc00c 为例:
bin(int('c00c',base=16)) ---> '0b1100000000001100'
int('00000000001100',base=2) --->12 ,头2位都是11,表示域名采用消息压缩,偏移量为12
+ type 2个字节 0x0010 10表示TXT类型
+ class 2个字节 0x0001
+ time to live 4个字节 0x0000010e
+ data length 2个字节 0x0010
+ data 变长 = (txt length 1个字节 0x0f + txt content组成)
data:image/s3,"s3://crabby-images/5ba05/5ba05310ef389458344255fca05cd46e6341fc03" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
2. MX类型 建立电子邮箱服务,将指向邮件服务器地址,需要设置MX记录。建立邮箱时,一般会根据邮箱服务商提供的MX记录填写此记录
data:image/s3,"s3://crabby-images/a3ccf/a3ccf10ba42242549ab08d165ffd85e718382ed1" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
name 2个字节 域名重复出现的时候采用消息压缩。头2位都是11,用于与标识区区别,后14位表示偏移量
以0xc00c 为例:
bin(int('c00c',base=16)) ---> '0b1100000000001100'
int('00000000001100',base=2) --->12 ,头2位都是11,表示域名采用消息压缩,偏移量为12
+ type 2个字节 0x000f 15表示MX类型
+ class 2个字节 0x0001
+ time to live 4个字节 0x00000228
+ data length 2个字节 0x000a
+ data 变长 = (preference优先级 2个字节 0x0028
+ mail exchange组成 0x 05 73 6d 74 70 34 c0 0c --> smtp4.google.com)
data:image/s3,"s3://crabby-images/34d6a/34d6a15ea2543ace8d566773b6e24cc35f591669" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
3. A类型
data:image/s3,"s3://crabby-images/a493d/a493dbc94a28e2b8577a53085bc8a57c558a1df5" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
name 2个字节 域名重复出现的时候采用消息压缩。头2位都是11,用于与标识区区别,后14位表示偏移量
以0xc02a 为例:
bin(int('c02a',base=16)) ---> '0b1100000000101010'
int('00000000101010',base=2) --->42 ,头2位都是11,表示域名采用消息压缩,偏移量为42
+ type 2个字节 0x0001 1表示A类型
+ class 2个字节 0x0001
+ time to live 4个字节 0x00000258
+ data length 2个字节 0x0004
+ data 变长 = (ip地址 0x d8ef251a
int('d8ef251a',base=16) ----> 3639551258
socket.inet_ntoa(struct.pack('!L',3639551258)) ---> 216.239.37.26
)
data:image/s3,"s3://crabby-images/00276/002765cccf38b8b3c4ba27aa1e4ceee7ee3b4b2e" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
data:image/s3,"s3://crabby-images/f8ef6/f8ef6851265e92c879aaa589d67ab6bafa7b2422" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
name 2个字节 域名重复出现的时候采用消息压缩。头2位都是11,用于与标识区区别,后14位表示偏移量
以0xc00c 为例:
bin(int('c00c',base=16)) ---> '0b1100000000001100'
int('00000000001100',base=2) --->12 ,头2位都是11,表示域名采用消息压缩,偏移量为12
+ type 2个字节 0x000c 12表示PTR类型
+ class 2个字节 0x0001
+ time to live 4个字节 0x00015125
+ data length 2个字节 0x0020
+ data 变长
data:image/s3,"s3://crabby-images/31873/318738f971348a900f0572aa075bcf2d929965cf" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
data:image/s3,"s3://crabby-images/26ed1/26ed1a53cf9c53ef66448de913f4adbd650c7ba9" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
以0xc00c 为例:
bin(int('c00c',base=16)) ---> '0b1100000000001100'
int('00000000001100',base=2) --->12 ,头2位都是11,表示域名采用消息压缩,偏移量为12
+ type 2个字节 0x001c 28表示PTR类型
+ class 2个字节 0x0001
+ time to live 4个字节 0x00015180
+ data length 2个字节 0x0010
+ data 变长
6. CNAME类型 如果将域名指向一个域名,实现与被指向域名相同的访问效果,需要增加CNAME记录。这个域名一般是主机服务商提供的一个域名
data:image/s3,"s3://crabby-images/1f315/1f31575cca9bf39954ada7361ea1f57c68ba6367" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
以0xc00c 为例:
bin(int('c00c',base=16)) ---> '0b1100000000001100'
int('00000000001100',base=2) --->12 ,头2位都是11,表示域名采用消息压缩,偏移量为12
+ type 2个字节 0x0005 5表示CNAME类型
+ class 2个字节 0x0001
+ time to live 4个字节 0x00000279
+ data length 2个字节 0x0008
+ data 变长 ( 0x 03 77 77 77 01 6c c0 10 --- www.l.google.com)
data:image/s3,"s3://crabby-images/537ef/537ef3ac2c4a52857213213176a7819f0067f6a6" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
data:image/s3,"s3://crabby-images/8660f/8660ffc12cedba7553753489d395f26b01e0b9bb" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
name 2个字节 域名重复出现的时候采用消息压缩。头2位都是11,用于与标识区区别,后14位表示偏移量
以0xc00c 为例:
bin(int('c00c',base=16)) ---> '0b1100000000001100'
int('00000000001100',base=2) --->12 ,头2位都是11,表示域名采用消息压缩,偏移量为12
+ type 2个字节 0x0002 2表示NS类型
+ class 2个字节 0x0001
+ time to live 4个字节 0x0000000e
+ data length 2个字节 0x000e
+ data 变长 ( 0x 06 6e 73 2d 65 78 74 04 6e 72 74 31 c0 0c --- ns-ext.nrt1.isc.org)
data:image/s3,"s3://crabby-images/b8f36/b8f36a92840b6359dfe1ea86fb1c084fcaff208a" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
data:image/s3,"s3://crabby-images/42509/42509f287412be1c1fde853813f2e37f4efd29ab" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
data:image/s3,"s3://crabby-images/52cca/52ccafc96e53372f874fb36bbb19fbb7d9b436f7" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
+ type 2个字节 0x0006 6表示SOA类型
+ class 2个字节 0x0001
+ time to live 4个字节 0x00000005
+ data length 2个字节 0x0040
+ data 变长 (Primary Name Server
+ Responsible authority's mailbox
+ serial number 4个字节
+ refresh interval 4个字节
+ retry Interval 4个字节
+ expire limit 4个字节
+ minimum ttl 4个字节)
data:image/s3,"s3://crabby-images/24efc/24efc4f210942c9e7b0393f8b5fcd75a50a3c9a2" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
data:image/s3,"s3://crabby-images/5e171/5e17145a0546025b872e11db1080301dafb22494" alt="十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体 十二、TCP/IP协议分析-DNS协议 - 碳基体 - 碳基体"
+ type 2个字节 0x0021 33表示SRV类型
+ class 2个字节 0x0001
+ time to live 4个字节 0x00000258
+ data length 2个字节 0x001a
+ data 变长 (Priority 2个字节
+ weight 2个字节
+ Port 2个字节
+ target)