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记录冲突的问题。

相关内容

热门资讯

安卓换鸿蒙系统会卡吗,体验流畅... 最近手机圈可是热闹非凡呢!不少安卓用户都在议论纷纷,说鸿蒙系统要来啦!那么,安卓手机换上鸿蒙系统后,...
app安卓系统登录不了,解锁登... 最近是不是你也遇到了这样的烦恼:手机里那个心爱的APP,突然就登录不上了?别急,让我来帮你一步步排查...
安卓系统拦截短信在哪,安卓系统... 你是不是也遇到了这种情况:手机里突然冒出了很多垃圾短信,烦不胜烦?别急,今天就来教你怎么在安卓系统里...
安卓系统要维护多久,安卓系统维... 你有没有想过,你的安卓手机里那个陪伴你度过了无数日夜的安卓系统,它究竟要陪伴你多久呢?这个问题,估计...
windows官网系统多少钱 Windows官网系统价格一览:了解正版Windows的购买成本Windows 11官方价格解析微软...
安卓系统如何卸载app,轻松掌... 手机里的App越来越多,是不是感觉内存不够用了?别急,今天就来教你怎么轻松卸载安卓系统里的App,让...
怎么复制照片安卓系统,操作步骤... 亲爱的手机控们,是不是有时候想把自己的手机照片分享给朋友,或者备份到电脑上呢?别急,今天就来教你怎么...
安卓系统应用怎么重装,安卓应用... 手机里的安卓应用突然罢工了,是不是让你头疼不已?别急,今天就来手把手教你如何重装安卓系统应用,让你的...
iwatch怎么连接安卓系统,... 你有没有想过,那款时尚又实用的iWatch,竟然只能和iPhone好上好?别急,今天就来给你揭秘,怎...
iphone系统与安卓系统更新... 最近是不是你也遇到了这样的烦恼?手机更新系统总是失败,急得你团团转。别急,今天就来给你揭秘为什么iP...