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 Studio ... 要解决Android Studio 4无法检测到Java代码,无法打开SDK管理器和设置的问题,可以...
安装tensorflow mo... 要安装tensorflow models object-detection软件包和pandas的每个...
安装了Laravelbackp... 检查是否创建了以下自定义文件并进行正确的配置config/backpack/base.phpconf...
安装了centos后会占用多少... 安装了CentOS后会占用多少内存取决于多个因素,例如安装的软件包、系统配置和运行的服务等。通常情况...
按照Laravel方式通过Pr... 在Laravel中,我们可以通过定义关系和使用查询构建器来选择模型。首先,我们需要定义Profile...
按照分类ID显示Django子... 在Django中,可以使用filter函数根据分类ID来筛选子类别。以下是一个示例代码:首先,假设你...
Android Studio ... 要给出包含代码示例的解决方法,我们可以使用Markdown语法来展示代码。下面是一个示例解决方案,其...
Android Retrofi... 问题描述:在使用Android Retrofit进行GET调用时,获取的响应为空,即使服务器返回了正...
Alexa技能在返回响应后出现... 在开发Alexa技能时,如果在返回响应后出现问题,可以按照以下步骤进行排查和解决。检查代码中的错误处...
Airflow Dag文件夹 ... 要忽略Airflow中的笔记本检查点,可以在DAG文件夹中使用以下代码示例:from airflow...