实现阿里云DDNS解析[通俗易懂]

实现阿里云DDNS解析[通俗易懂]我有三种设备,synologyopenwrtraspberryopenwrt1,首先,我在openwrt上实现,这有分为二种方法,其实也是一种方法,1,下载ddns-scripts_aliyun_1.0.0-1_all.ipk这个安装包,直接安装,在app-ddns里面就可以看到阿里去的服务商了,然后输入用户名,密码就可以了。2,使用自定义的脚本也行,raspberrysynology…

大家好,又见面了,我是你们的朋友全栈君。

我有三种设备,synology openwrt raspberry

openwrt

1,首先,我在openwrt上实现, 这有分为二种方法,其实也是一种方法, 1, 下载ddns-scripts_aliyun_1.0.0-1_all.ipk这个安装包,直接安装,在app-ddns里面就可以看到阿里去的服务商了, 然后输入用户名,密码就可以了。

2, 使用自定义的脚本也行, 

raspberry

先安装python库

pip3 install aliyunsdkcore

pip3 install aliyun-python-sdk-alidns

网上下载https://shumeipai.nxez.com/2020/01/10/raspberry-pi-ddns-for-external-network-access.html

ddns.py

修改自己的ID  KEY,主机名。

执行 python3 ddns.py &

synology

在群晖上可以使用2种方法,1, docker, 这个我没有试。  2是使用脚本,我个我试了,比较方便, 网上下载了一个aliyun.sh, 加到群晖的自定义任务里,10分钟运行一次,就可以了,非常简单方便易行。

主机记录:主机记录就是域名前缀,常见用法有:

  • www:解析后的域名为 www.1756260160.com

sh aliyun.sh <id> <secret> <主域名> <主机记录>

sh /var/services/homes/wandersky/aliddns/aliyun.sh L******************74 V0********************CMi **********.com www

脚本命令格式如上。

#!/bin/sh

set -e

if [ $1 ]; then
    ApiId=$1
fi

if [ $2 ]; then
    ApiKey=$2
fi

if [ $3 ]; then
    Domain=$3
fi

if [ -z “$ApiId” -o -z “$ApiKey” -o -z “$Domain” ]; then
    echo “参数缺失”
    exit 1
fi

if [ $4 ]; then
    SubDomain=$4
fi

if [ -z “$SubDomain” ]; then
    SubDomain=”@”
fi

Nonce=$(date -u “+%N”)    # 有bug?
Timestamp=$(date -u “+%Y-%m-%dT%H%%3A%M%%3A%SZ”)    # SB 阿里云, 什么鬼时间格式
Nonce=$Timestamp

urlencode() {

    local raw=”$1″;
    local len=”${#raw}”
    local encoded=””

    for i in `seq 1 $len`; do
        local j=$((i+1))
        local c=$(echo $raw | cut -c$i-$i)

        case $c in [a-zA-Z0-9.~_-]) ;;
            *)
            c=$(printf ‘%%%02X’ “‘$c”) ;;
        esac

        encoded=”$encoded$c”
    done

    echo $encoded
}

# $1 = query string
getSignature() {

    local encodedQuery=$(urlencode $1)
    local message=”GET&%2F&$encodedQuery”
    local sig=$(echo -n “$message” | openssl dgst -sha1 -hmac “$ApiKey&” -binary | openssl base64)
    echo $(urlencode $sig)
}

sendRequest() {

    local sig=$(getSignature $1)
    local result=$(wget -qO- –no-check-certificate –content-on-error “https://alidns.aliyuncs.com?$1&Signature=$sig”)
    echo $result
}

getRecordId() {

    echo “获取 $SubDomain.$Domain 的 IP…” >&2
    local queryString=”AccessKeyId=$ApiId&Action=DescribeSubDomainRecords&Format=JSON&SignatureMethod=HMAC-SHA1&SignatureNonce=$Nonce&SignatureVersion=1.0&SubDomain=$SubDomain.$Domain&Timestamp=$Timestamp&Type=A&Version=2015-01-09″
    local result=$(sendRequest “$queryString”)
    local code=$(echo $result | sed ‘s/.*,”Code”:”\([A-z]*\)”,.*/\1/’)
    local recordId=$(echo $result | sed ‘s/.*,”RecordId”:”\([0-9]*\)”,.*/\1/’)

    if [ “$code” = “$result” ] && [ ! “$recordId” = “$result” ]; then
        local ip=$(echo $result | sed ‘s/.*,”Value”:”\([0-9\.]*\)”,.*/\1/’)

        if [ “$ip” == “$NewIP” ]; then
            echo “IP 无变化, 退出脚本…” >&2
            echo “quit”
        else
            echo $recordId
        fi
    else
        echo “null”
    fi
}

# $1 = record ID, $2 = new IP
updateRecord() {

    local queryString=”AccessKeyId=$ApiId&Action=UpdateDomainRecord&DomainName=$Domain&Format=JSON&RR=$SubDomain&RecordId=$1&SignatureMethod=HMAC-SHA1&SignatureNonce=$Nonce&SignatureVersion=1.0&Timestamp=$Timestamp&Type=A&Value=$2&Version=2015-01-09″
    local result=$(sendRequest $queryString)
    local code=$(echo $result | sed ‘s/.*,”Code”:”\([A-z]*\)”,.*/\1/’)

    if [ “$code” = “$result” ]; then
        echo “$SubDomain.$Domain 已指向 $NewIP.” >&2
    else
        echo “更新失败.” >&2
        echo $result >&2
    fi
}

# $1 = new IP
addRecord() {

    local queryString=”AccessKeyId=$ApiId&Action=AddDomainRecord&DomainName=$Domain&Format=JSON&RR=$SubDomain&SignatureMethod=HMAC-SHA1&SignatureNonce=$Nonce&SignatureVersion=1.0&Timestamp=$Timestamp&Type=A&Value=$1&Version=2015-01-09″
    local result=$(sendRequest $queryString)
    local code=$(echo $result | sed ‘s/.*,”Code”:”\([A-z]*\)”,.*/\1/’)

    if [ “$code” = “$result” ]; then
        echo “$SubDomain.$Domain 已指向 $NewIP.” >&2
    else
        echo “添加失败.” >&2
        echo $result >&2
    fi
}

# Get new IP address
echo “获取当前 IP…”
NewIP=$(wget -qO- –no-check-certificate “http://members.3322.org/dyndns/getip”)
echo “当前 IP 为 $NewIP.”

# Get record ID of sub domain
recordId=$(getRecordId)

if [ ! “$recordId” = “quit” ]; then
    if [ “$recordId” = “null” ]; then
        echo “域名记录不存在, 添加 $SubDomain.$Domain 至 $NewIP…”
        addRecord $NewIP
    else
        echo “域名记录已存在, 更新 $SubDomain.$Domain 至 $NewIP…”
        updateRecord $recordId $NewIP
    fi
fi

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/134242.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 快速上手Linux玩转典型应用

    快速上手Linux玩转典型应用

  • rocketmq延迟队列原理_rocketmq延迟队列原理

    rocketmq延迟队列原理_rocketmq延迟队列原理在java的延迟队列中,无法支持集群的延迟。Redis可以做到对应的延迟功能,但是自己封装毕竟局限于业务。而且封装也需要耗费一定时间。今天我们就讲一个现有的延迟队列,不仅支持分布式服务,而且解耦业务代码,而且支持不同延迟时间的造好的轮子吧。~那就是RocketMQ延时队列。RocketMQ将延时队列的延时延时时间分为18个级别123456789101112131415161718分别对应下面的延迟时间,在使用时,直接传递level即可。mess

  • springaop的使用_Spring注解

    springaop的使用_Spring注解目录SpringAOP简介AOP概念SpringAOP简单流程图SpringAOP之Annotation前置通知(Beforeadvice)返回后通知(Afterreurningadvice)抛出异常后通知(Afterthrowingadvice)后置通知(After(finally)advice)环绕通知(Aroundadvice)引入…

  • Server.MapPath()用法[通俗易懂]

    Server.MapPath()用法[通俗易懂]Server.MapPath(stringpath)作用是返回与Web服务器上的指定虚拟路径相对应的物理文件路径。其参数path为Web服务器的虚拟路径,返回结果是与path相对应的物理文件路径。但有时参数并非为虚拟路径,而是用户自定义的文件名。  Server.MapPath()的全名是System.Web.HttpContext.Current.Server.MapPath()。有

  • 【CEGUI】CEGUI入门篇之创建window(四)

    【CEGUI】CEGUI入门篇之创建window(四)以下内容翻译自http://static.cegui.org.uk/docs/0.8.7/window_tutorial.html这里介绍CEGUIwindow的创建及如何让window在屏幕上显示出来,在此之前,需要了解“CEGUI入门篇之初始化(一)”、“CEGUI入门篇之使用ResourceProvider加载资源(二)”和“CEGUI入门篇之数据文件及默认初始化(三)”。1、window和

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号