Python学习笔记-DNS处理模块dnspython

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介:

DNS处理模块dnspython

    dnspython是python实现的一个DNS工具包,它支持几乎所有的记录类型,可以用于查询、传输并动态更新ZONE信息,同时支持TSIG(事务签名)验证消息和EDNS0(扩展DNS)。

在系统管理方面,我们可以利用其查询功能来实现DNS服务监控以及解析结果的校验,可以替代nslookup和dig等工具,轻松做到与现有平台的整合。

    下载dnspython模块

1
[root@kurol ~] # python3 -m easy_install -i http://pypi.douban.com/simple/ dnspython

    dnspython提供大量关于DNS的处理方法,最常用的是域名查询。dnspython提供了一个DNS解析类resolver,使用它的query方法来实现域名的查询功能。 

1
query( self , qname, rdtype  =  1 , rdclass  =  1 , tcp  =  False , source  =  None , raise_on_no_answer  =  True , source_port  =  0 )


    qname参数为查询的域名,rdtype参数用来指定RR资源。 

A记录 将主机名转换成IP地址 
MX记录 邮件交换记录,定义邮件服务器的域名 
CNAME记录 别名记录,实现域名间的映射 
NS记录 标记区域的域名服务器及授权子域 
PTR记录 反向解析,与A记录相反,将IP地址转换为主机名 
SOA记录 SOA标记,一个起始授权区的定义


    常见的解析类型示例:

        A记录(实现A记录查询方法源码):  

?
1
   [root@kurol pkg1] # vim dnsa.py
1
2
3
4
5
6
#!/usr/bin/python3
#import dns.resolverdomain = input('Please input an domain: ')    #输入域名地址
=  dns.resolver.query(domain,  'A' )      #指定查询类型为A记录
for  in  A.response.answer:      #通过response.answer方法获取查询回应信息    
for  in  i.items:    #遍历回应信息        
     print  (j.address)
?
1
[root@kurol pkg1] # python3 dnsa.py Please input an domain: www.google.com93.46.8.89


        MX记录(实现MX记录查询方法源码):

?
1
[root@kurol pkg1] # vim mxdns.py
1
2
3
4
5
#!/usr/bin/python3
#import dns.resolverdomain = input('Please input an domain: ') #输入域名地址
MX  =  dns.resolver.query(domain,  'MX' #指定查询类型为MX记录
for  in  MX:  #通过response.answer方法获取查询回应信息    
     print  ( 'MX preference = ' , i.preference,  'main exchanger = ' , i.exchange)
1
2
3
4
5
6
[root@kurol pkg1] # python3 mxdns.py 
Please  input  an domain: baidu.com
MX preference  =  20  main exchanger  =  mx50.baidu.com.
MX preference  =  10  main exchanger  =  mx.n.shifen.com.
MX preference  =  20  main exchanger  =  mx1.baidu.com.
MX preference  =  20  main exchanger  =  jpmx.baidu.com.


        NS记录(实现NS记录查询方法源码):

?
1
[root@kurol pkg1] # vim nsdns.py
1
2
3
4
5
#!/usr/bin/python3#import dns.resolverdomain = input('Please input an domain: ') #输入域名地址
ns  =  dns.resolver.query(domain,  'NS' #指定查询类型为NS记录
for  in  ns.response.answer:  #通过response.answer方法获取查询回应信息    
for  in  i.items:  #遍历回应信息        
     print  (j.to_text())
1
2
3
4
5
6
[root@kurol pkg1] # python3 nsdns.py 
Please  input  an domain: qq.comn
s3.qq.com.
ns4.qq.com.
ns1.qq.com.
ns2.qq.com.


        CNAME记录(实现CNAME记录查询方法源码):

?
1
[root@kurol pkg1] # vim cnamedns.py
1
2
3
4
5
#!/usr/bin/python3#import dns.resolverdomain = input('Please input an domain: ') #输入域名地址
cname  =  dns.resolver.query(domain,  'CNAME' #指定查询类型为CNAME记录
for  in  ns.response.answer:  #通过response.answer方法获取查询回应信息    
for  in  i.items:  #遍历回应信息
     print  (j.to_text())



      本文转自谢育政 51CTO博客,原文链接:http://blog.51cto.com/kurolz/1935039 ,如需转载请自行联系原作者


相关文章
|
1月前
|
Python
Python Internet 模块
Python Internet 模块。
124 74
|
10天前
|
数据采集 供应链 API
Python爬虫与1688图片搜索API接口:深度解析与显著收益
在电子商务领域,数据是驱动业务决策的核心。阿里巴巴旗下的1688平台作为全球领先的B2B市场,提供了丰富的API接口,特别是图片搜索API(`item_search_img`),允许开发者通过上传图片搜索相似商品。本文介绍如何结合Python爬虫技术高效利用该接口,提升搜索效率和用户体验,助力企业实现自动化商品搜索、库存管理优化、竞品监控与定价策略调整等,显著提高运营效率和市场竞争力。
39 3
|
12天前
|
Python
[oeasy]python057_如何删除print函数_dunder_builtins_系统内建模块
本文介绍了如何删除Python中的`print`函数,并探讨了系统内建模块`__builtins__`的作用。主要内容包括: 1. **回忆上次内容**:上次提到使用下划线避免命名冲突。 2. **双下划线变量**:解释了双下划线(如`__name__`、`__doc__`、`__builtins__`)是系统定义的标识符,具有特殊含义。
24 3
|
1月前
|
数据采集 JSON API
如何利用Python爬虫淘宝商品详情高级版(item_get_pro)API接口及返回值解析说明
本文介绍了如何利用Python爬虫技术调用淘宝商品详情高级版API接口(item_get_pro),获取商品的详细信息,包括标题、价格、销量等。文章涵盖了环境准备、API权限申请、请求构建和返回值解析等内容,强调了数据获取的合规性和安全性。
|
29天前
|
数据挖掘 vr&ar C++
让UE自动运行Python脚本:实现与实例解析
本文介绍如何配置Unreal Engine(UE)以自动运行Python脚本,提高开发效率。通过安装Python、配置UE环境及使用第三方插件,实现Python与UE的集成。结合蓝图和C++示例,展示自动化任务处理、关卡生成及数据分析等应用场景。
113 5
|
1月前
|
存储 缓存 Python
Python中的装饰器深度解析与实践
在Python的世界里,装饰器如同一位神秘的魔法师,它拥有改变函数行为的能力。本文将揭开装饰器的神秘面纱,通过直观的代码示例,引导你理解其工作原理,并掌握如何在实际项目中灵活运用这一强大的工具。从基础到进阶,我们将一起探索装饰器的魅力所在。
|
1月前
|
Android开发 开发者 Python
通过标签清理微信好友:Python自动化脚本解析
微信已成为日常生活中的重要社交工具,但随着使用时间增长,好友列表可能变得臃肿。本文介绍了一个基于 Python 的自动化脚本,利用 `uiautomator2` 库,通过模拟用户操作实现根据标签批量清理微信好友的功能。脚本包括环境准备、类定义、方法实现等部分,详细解析了如何通过标签筛选并删除好友,适合需要批量管理微信好友的用户。
67 7
|
2月前
|
XML 数据采集 数据格式
Python 爬虫必备杀器,xpath 解析 HTML
【11月更文挑战第17天】XPath 是一种用于在 XML 和 HTML 文档中定位节点的语言,通过路径表达式选取节点或节点集。它不仅适用于 XML,也广泛应用于 HTML 解析。基本语法包括标签名、属性、层级关系等的选择,如 `//p` 选择所有段落标签,`//a[@href='example.com']` 选择特定链接。在 Python 中,常用 lxml 库结合 XPath 进行网页数据抓取,支持高效解析与复杂信息提取。高级技巧涵盖轴的使用和函数应用,如 `contains()` 用于模糊匹配。
|
2月前
|
测试技术 开发者 Python
使用Python解析和分析源代码
本文介绍了如何使用Python的`ast`模块解析和分析Python源代码,包括安装准备、解析源代码、分析抽象语法树(AST)等步骤,展示了通过自定义`NodeVisitor`类遍历AST并提取信息的方法,为代码质量提升和自动化工具开发提供基础。
100 8
|
存储 Linux 索引
python基础学习笔记
服务器 1.ftp服务器         FTP是FileTransferProtocol(文件传输协议)的英文简称,中文名称为“文传协议”。
1525 0

相关产品

  • 云解析DNS
  • 推荐镜像

    更多