acme-challenge和TXT记录冲突。
创始人
2024-07-23 14:00:57
0

ACME协议是利用DNS验证域名所有权的一种方式,其中需要在DNS服务器上添加一个名为“acme-challenge”的TXT记录。但是,如果在该域名上已经有了同名的TXT记录,就会导致冲突。解决该问题的方法是可以在添加“acme-challenge”记录时先删除同名的TXT记录。

示例代码如下:

import os
import dns.resolver
from certbot import main as certbot_main

# 检查是否有同名的TXT记录
def check_txt_record(domain):
    challenge_domain = '_acme-challenge.' + domain
    answers = dns.resolver.query(challenge_domain, 'TXT')
    if answers:
        for rdata in answers:
            txt_record = str(rdata).strip('"')
            if txt_record:
                return True
    return False

# 添加ACME验证记录
def add_challenge_record(domain, token):
    command = f"certbot certonly --manual --preferred-challenges=dns --manual-public-ip-logging-ok -d {domain} --manual-auth-hook '/usr/bin/env python add_dns_record.py {domain} {token}'"
    os.system(command)

# 删除同名的TXT记录
def delete_txt_record(domain):
    challenge_domain = '_acme-challenge.' + domain
    txt_records = dns.resolver.query(challenge_domain, 'TXT')
    if txt_records:
        for rdata in txt_records:
            txt_record = str(rdata).strip('"')
            delete_dns_record(challenge_domain, 'TXT', txt_record)

# 删除DNS记录
def delete_dns_record(domain, record_type, value):
    cmd = f"sh /usr/local/bin/dns.sh delete {domain} {record_type} '{value}'"
    os.system(cmd)

# 添加DNS记录
def add_dns_record(domain, record_type, value):
    cmd = f"sh /usr/local/bin/dns.sh add {domain} {record_type} '{value}'"
    os.system(cmd)

# 获取ACME验证token
def get_acme_token(domain):
    token = ''
    cmd = f"echo $TOKEN_{domain}"
    output = os.popen(cmd).read()
    if output:
        token = output.strip()
    return token

# 添加ACME验证记录并删除同名的TXT记录
def add_challenge_and_delete_txt_record(domain):
    token = get_acme_token(domain)
    if not check_txt_record(domain):
        add_challenge_record(domain, token)
        delete_txt_record(domain)

# 主函数
if __name__ == '__main__':
    domain = 'example.com'
    add_challenge_and_delete_txt_record(domain)

运行该代码时,会先检查是否有同名的TXT记录,如果有则删除该记录,然后再添加ACME验证记录。这样就能避免“acme-challenge”和TXT记录冲突的问题。

相关内容

热门资讯

Android Recycle... 要在Android RecyclerView中实现滑动卡片效果,可以按照以下步骤进行操作:首先,在项...
安装apache-beam==... 出现此错误可能是因为用户的Python版本太低,而apache-beam==2.34.0需要更高的P...
Android - 无法确定任... 这个错误通常发生在Android项目中,表示编译Debug版本的Java代码时出现了依赖关系问题。下...
Android - NDK 预... 在Android NDK的构建过程中,LOCAL_SRC_FILES只能包含一个项目。如果需要在ND...
Akka生成Actor问题 在Akka框架中,可以使用ActorSystem对象生成Actor。但是,当我们在Actor类中尝试...
Agora-RTC-React... 出现这个错误原因是因为在 React 组件中使用,import AgoraRTC from “ago...
Alertmanager在pr... 首先,在Prometheus配置文件中,确保Alertmanager URL已正确配置。例如:ale...
Aksnginxdomainb... 在AKS集群中,可以使用Nginx代理服务器实现根据域名进行路由。以下是具体步骤:部署Nginx i...
AddSingleton在.N... 在C#中创建Singleton对象通常是通过私有构造函数和静态属性来实现,例如:public cla...
Alertmanager中的基... Alertmanager中可以使用repeat_interval选项指定在一个告警重复发送前必须等待...