编写Python脚本在域名过期10天内将域名信息发送到钉钉

1、config.json配置文件

json 复制代码
{
    "dingtalk-webhook": "https://oapi.dingtalk.com/robot/send?access_token=XXXXXXXXXXXXXX",
    "secret": "XXXXXXXXXXXXXXXXXXXXXX",
    "domains": [
        "www.advd.tel",
        "dre.dfefer.cn:8443"
    ]
}

2、python正文

python 复制代码
import json
import datetime
import time
import hmac
import hashlib
import base64
import urllib.parse
import requests
import argparse
import whois
import tldextract
import os

CONFIG_FILE = 'config.json'   # 你的配置文件路径
ALERT_DAYS = 10               # 小于多少天触发告警

def load_config(config_file):
    """加载配置文件"""
    if not os.path.exists(config_file):
        print(f"[ERROR] 配置文件不存在: {config_file}")
        sys.exit(1)
    with open(config_file, 'r', encoding='utf-8') as f:
        return json.load(f)

def sign_dingtalk(secret):
    """生成钉钉安全签名"""
    timestamp = str(round(time.time() * 1000))
    string_to_sign = f'{timestamp}\n{secret}'
    hmac_code = hmac.new(secret.encode('utf-8'),
                         string_to_sign.encode('utf-8'),
                         digestmod=hashlib.sha256).digest()
    sign = urllib.parse.quote_plus(base64.b64encode(hmac_code))
    return timestamp, sign

def send_dingtalk_message(webhook, secret, message):
    """发送钉钉告警消息"""
    timestamp, sign = sign_dingtalk(secret)
    url = f"{webhook}&timestamp={timestamp}&sign={sign}"
    headers = {'Content-Type': 'application/json'}
    data = {
        "msgtype": "text",
        "text": {"content": message}
    }
    try:
        resp = requests.post(url, headers=headers, data=json.dumps(data))
        resp.raise_for_status()
        print(f"[+] 已发送钉钉告警: {message}")
    except Exception as e:
        print(f"[!] 发送钉钉失败: {e}")

def get_root_domain(domain):
    """提取顶级域名"""
    ext = tldextract.extract(domain)
    return f"{ext.domain}.{ext.suffix}"

def check_domain_expiry(domain):
    """获取域名过期时间"""
    try:
        w = whois.whois(domain)
        expiry_date = w.expiration_date
        if isinstance(expiry_date, list):
            expiry_date = expiry_date[0]
        return expiry_date
    except Exception as e:
        print(f"[!] 获取 {domain} 过期时间失败: {e}")
        return None

def main():
    # 添加命令行参数
    parser = argparse.ArgumentParser(description="Domain Expiry Monitor")
    parser.add_argument("--config-file", required=True, help="Path to configuration JSON file")
    args = parser.parse_args()

    config = load_config(args.config_file)
    #config = load_config()
    webhook = config["dingtalk-webhook"]
    secret = config["secret"]
    domains = config["domains"]

    alerts = []
    now = datetime.datetime.now()

    for domain in domains:
        root_domain = get_root_domain(domain)
        expiry = check_domain_expiry(root_domain)
        if not expiry:
            continue
        if isinstance(expiry, datetime.date):
            expiry = datetime.datetime.combine(expiry, datetime.time.min)
        days_left = (expiry - now).days

        print(f"{domain} 到期时间: {expiry}, 剩余 {days_left} 天")

        if days_left < ALERT_DAYS:
            alerts.append(f"⚠️ 域名 {domain} 即将过期,仅剩 {days_left} 天!(到期日: {expiry.date()})")

    if alerts:
        message = "\n".join(alerts)
        send_dingtalk_message(webhook, secret, message)
    else:
        print("✅ 所有域名都在安全期内。")

if __name__ == '__main__':
    main()

3、执行命令

bash 复制代码
05 00 * * * cd /root/domain && /usr/bin/python3 domain_expiry_monitor.py --config-file config.json /root/domain/domain_expiry_monitor.log 2>&1

4、告警信息图示

相关推荐
薇茗3 分钟前
【初阶数据结构】 升沉有序的平仄 排序 3
c语言·开发语言·数据结构·算法·排序算法·文件归并排序
2401_868534784 分钟前
论快速应用开发方法及应用
大数据·python
字节高级特工5 分钟前
C++11(一) 革新:右值引用与移动语义
java·开发语言·c++·人工智能·后端
郝学胜-神的一滴6 分钟前
系统设计 012:从用户系统出发,吃透缓存、数据库与高并发设计
java·数据库·python·缓存·php·软件构建
AI科技星10 分钟前
强哥德巴赫猜想(1+1)终极证明(2026 年5月 21 日)
开发语言·人工智能·算法·计算机视觉·量子计算
人工智能导论实践课12 分钟前
奥比中光深度相机astra pro的初步ros包开发
人工智能·python
故事和你9115 分钟前
洛谷-【图论2-4】连通性问题2
开发语言·数据结构·c++·算法·动态规划·图论
Brilliantwxx16 分钟前
【C++】 二叉搜索树
开发语言·c++·算法
wj3055853789 小时前
课程 9:模型测试记录与 Prompt 策略
linux·人工智能·python·comfyui
为何创造硅基生物9 小时前
C语言 结构体内存对齐规则(通俗易懂版)
c语言·开发语言