DNS原理与手撸域名之自己解析域名

一、DNS解析场景

这世间很多实物都在悄然运转,没有惊天动地也没有春花秋月。哎,没错了,dns这玩意儿就是这样,平时不声不响,一旦没了它,上网那是不存在上网的了。

当你打开浏览器,输入 www.xxoo.com ,按下回车的那一秒,你的电脑又发生了什么呢?

其实在浏览器输入地址后,计算机并不能直接访问到网站,因为有相关网络基础的同学都知道,数据包在网络链路传输过程中,路由转发是数据能到达目的地的核心过程。而数据包在不停的转发过程犹如快递的转运,经过一次次我的转运最终发到你的手里。

而每次转运的过程只有来源和目的IP,这显然没有网址这个东西,而DNS就是把你要访问的网址换成IP地址。

二、DNS初识

打开网络设置,查看属性。或者适配器–》属性-》IPV4协议

DNS原理与手撸域名之自己解析域名插图

DNS原理与手撸域名之自己解析域名插图1

图中看到额DNS服务器,就是DNS提供服务的源头了。

三、DNS协议

直接上头,啊不是。直接上图,百度百科说的很对DNS原理与手撸域名之自己解析域名插图2

DNS究其源,就是一个在 UDP层指定数据报内容规则和业务逻辑的这么一个协议。

再简单点说,这个DNS协议,就是一个报文格式规定。告诉你报文里哪几个字节是什么内容,你按照这个内容来组建报文,就可以进行DNS解析了。

意思就是说,我可以自己组建一个UDP报文?发给DNS服务器的端口?然后就能返回一个符合DNS协议的报文,里面包含了解析出的IP地址?

开干。

四、截取DNS报文

直接打开wireshark,随便设置一下截包过滤器,随便打开一个CMD,随便想一下,PING网址可以得到地址,盲猜这其中一定有dns解析,开搞

DNS原理与手撸域名之自己解析域名插图3

五、DNS报文分析

这个就很简单了,百度一下DNS协议的的报文格式,这玩意儿是UDP,所以第一个包发请求,第二个包就是响应了。

DNS原理与手撸域名之自己解析域名插图4

百度一下,看大家说的DNS报文格式是啥样的。同理结合截包的报文分析。

DNS原理与手撸域名之自己解析域名插图5

小鲨鱼都标的很清楚了,每个字段对应的名字和字节数目。请求就这么回事。OK,咱去组一个试试。

六、自己发送DNS报文

随便去找一个UDP测试工具,就以114.114.114.114试试,就以刚才的www.baidu.com为例子,发个包看看有没有回应。nice啊,直接收到DNS的响应包。

OK对着小鲨鱼截的包对照分析一下,看合不合得上。

DNS原理与手撸域名之自己解析域名插图6

DNS原理与手撸域名之自己解析域名插图7

没有问题啊,可以看出,最后4字节就是IP地址,于是我们用计算器大致算一下,看结果对不对。

DNS原理与手撸域名之自己解析域名插图8

用计算器16进制逐字节转换,算出DNS解出的结果是 ​​​​​​39.156.66.14

浏览器验证一下:

DNS原理与手撸域名之自己解析域名插图9

没有问题,完全符合我们的猜想,编写代码试试。

七、编写代码解析DNS实现域名解析

简单地上代码写上几行,搞个UDP 发送接收看看。

DNS原理与手撸域名之自己解析域名插图10

收工!

原文链接:https://blog.csdn.net/qq_31314583/article/details/123397333

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享