Python免登录实现域名解析的示例详解
作者:Python技术 发布时间:2022-12-17 21:26:50
标签:Python,域名,解析
写此篇文章,我花10块购买了域名ssw.ski。
目的是编写python脚本,通过dnspod api获取个人域名内的dns解析记录,
免登录实现域名的解析、修改和删除:
为什么要编写这个脚本?当你在公司负责很多的域名又经常需要解析和查看,频繁登录网站去查去修改是一件费神的事。
上图的账号内有2个域名ssw.fit和ssw.ski,我想給ssw.ski增加了一条A记录,
把test子域名解析到我的linux云服务器,添加完后访问test.ssw.ski
如何获得域名解析信息
使用dnspod api, 说明见腾讯云文档:https://docs.dnspod.cn/api/call-requency/
#获取domain_id
curl 'https://dnsapi.cn/Domain.List' -d 'login_token=&format=json'
#获取record_id
curl 'https://dnsapi.cn/Record.List' -d 'login_token=&format=json&domain_id='
获取Token
访问https://console.dnspod.cn/account/token/token,创建一个秘钥
完成后程序中可以使用ID,TOKEN来访问api。
目标实现
一般都通过requests 的post方法访问对应网址。
不过这里用curl命令更简介方便,它也可以发起post请求,并且一条命令解决。
所以用python来执行linux下的curl命令就可以了:
class DomainHandler(object):
def __init__(self):
pass
def exec_cmd(self,cmd):
res = Popen(cmd, shell=True, stdout=PIPE)
ret = res.communicate()[0].decode('utf-8')
return ret.strip()
下面以添加A记录为例。
添加字典对应函数入口:
dic = {
'1':DomainHandler().add,
'2':DomainHandler().mod,
'3':DomainHandler().delete
}
tag = True
while tag:
print('''
1.增加
2.修改
3.删除
q.退出
''')
choice = input('\033[1;42m输入选项:\033[0m').strip()
if not choice:
continue
if choice == 'q':
break
if choice in dic:
dic[choice]()
else:
print('\033[31m选项不存在\033[0m')
添加记录的入口函数:
def add(self):
self.domain_info()
while tag:
self.domain_id = input('\033[1;42m输入域名ID:\033[0m').strip()
if self.domain_id == 'q':
break
if not self.domain_id or not self.domain_id.isdigit():
print('\033[31merror id\033[0m')
continue
self.sub_domain = input('\033[1;42m子域名[@或*等]:\033[0m').strip()
self.record_type = input('\033[1;42m类型[A或CNAME]:\033[0m').strip()
self.address = input('\033[1;42m记录值(ip或域名):\033[0m').strip()
if not self.sub_domain or not self.record_type or not self.address:
print('\033[31m参数不能为空\033[0m')
continue
self.add_Arecord(self.domain_id,self.sub_domain,self.record_type,self.address)
if self.domain_id == 'q' or self.record_type == 'q' or self.address == 'q':
self.tag = False
break
获取域名信息:
def domain_info(self):
cmd = 'curl -s https://dnsapi.cn/Domain.List -d "login_token=391845,92f408bb5343e&format=json"'
data = json.loads(self.exec_cmd(cmd))
print(data)
for item in data['domains']:
print('%s:%s' % (item['name'], item['id']))
添加记录:
def add_Arecord(self,domain_id,sub_domain,record_type,address):
print(domain_id,sub_domain,record_type,address)
cmd2 = "curl -s -X POST https://dnsapi.cn/Record.Create -d 'login_token=391845,92f408bb5343e&format=json&domain_id={0}&sub_domain={1}&record_type={2}&record_line_id=0&value={3}'".format(
domain_id, sub_domain, record_type, address)
r = json.loads(self.exec_cmd(cmd2))
print(r['status']['message'])
修改记录
我想把test.ssw.ski的ip修改为1.1.1.1
ipconfig/flushdns刷新一下dns缓存,生效了:
文章还没写完,它就检测到域名未备案了
不过前面的测试已经ok,就不备案了,
来源:https://mp.weixin.qq.com/s/vzalCf0UyehKi2ifjCmupA
0
投稿
猜你喜欢
- 今天在项目中用到了弹出子窗口,就想到了用JavaScript实现的两种方法,一个是window.open();一个是window.showM
- 本文实例讲述了python读写二进制文件的方法。分享给大家供大家参考。具体如下:初学python,现在要读一个二进制文件,查找doc只发现
- 这篇文章我们玩玩numpy的数值数据类型转换导入numpy>>> import numpy as np一、随便玩玩生成一个
- 我就废话不多说,直接上代码吧:# -*- coding: utf-8 -*-import osout=os.system('nets
- 前言大家都知道,早期的XMLHttpRequest不支持文件上传,一般用第三方js插件或者flash,现在可以借助XMLHttpReques
- 载入库绘制表格我们需要用到python库中的matplotlib库import matplotlib.pyplot as plt一、折线图#
- 本文实例讲述了js实现的xml对象转json功能。分享给大家供大家参考,具体如下:支持无限级别xml结构对象转json,并且支持任意标签属性
- 一、说明压缩和解压缩是日常常用的操作,不管是windows上图形界面的操作,还是linux上用命令来进行压缩解压缩,总的而言都还是比较方便的
- MySQL分区方便了我们的使用,但是MySQL分区究竟能做些什么,MySQL分区有没有什么限制呢?阅读下文,您就能找到答案。MySQL分区能
- 视频观看视频Pygame模块之pygame.draw本文将主要介绍Pygame的draw模块,主要内容翻译自pygame的官方文档pygam
- 本文实例为大家分享了python远程连接MySQL数据库的具体代码,供大家参考,具体内容如下连接数据库这里默认大家都已经配置安装好 MySQ
- 学习目的: 掌握ADO.NET打开SQL SERVER数据库的方法。 今天做个非常普通的例子,做一个用户登录框。主要是通过这个练习认识一下S
- 1.SGD随机梯度下降随机梯度下降和其他的梯度下降主要区别,在于SGD每次只使用一个数据样本,去计算损失函数,求梯度,更新参数。这种方法的计
- 本文我们总结了几个在安装SQL Server数据库时常见问题的解决方案,供初学者学习参考,接下来让我们来一起看一下吧。常见问题一:安装Sql
- 一般网站发布信息会在具体实现范围内发布,我们在进行网络爬虫的过程中,可以通过设置定时爬虫,定时的爬取网站的内容。使用python爬虫框架Sc
- 前言在日常的业务数据分析 ,可视化是非常重要的步骤。这里总结了matplotlib常用绘图技巧,希望可以帮助大家更加更加高效的、美观的显示图
- 目的工作中遇到一个需求,通过需要通过网站查询船舶名称得到MMSI码,网站来自船讯网。分析请求根据以往爬虫的经验,打开F12,通过输入船舶名称
- 根据当前时间戳获得整小时时间戳unit = 3600start_time = int(time.time())/3600 * 3600根据当
- 使用 python manage.py createsuperuser创建超级用户时只能默认输入:用户名,邮箱,及密码来创建有的时候我们需要
- excel 文件内容如下:读取excel内容:import xlrdfrom datetime import datetimefrom xl