首页 >>  正文

python设定输入值范围

来源:baiyundou.net   日期:2024-09-20

作者:拉德布鲁赫信徒

1 引言

首先声明一下使用场景,本文适用拥有动态公网ip的朋友,如果没有的话,那么这篇文章并不适合你,可以参照前面一篇中frp的内容进行食用。

本文已经考虑到大家在使用上的障碍,为了保障体验的一致,最后后附上源码,基本只需要按照本文的流程一步步设置下去,就可以实现对应的功能。

  • 为什需要需要ddns?


因为我们在使用nas或者服务器部署的docker应用的时候,难免会涉及到公网的问题。如果没有公网的话,那么你只可以在你的局域网内访问你的应用的,而这又极大地限制了使用场景。但是现在家用宽带极少会提供公网IP,即便是提供了,所给的也是动态的公网ip,通常会在几天之内变动一次,或者是每次断电后变动一次。这种情形下,采用IP+端口形式的访问就会失效。为了应对这种情况,有很多解决方案,而DDNS方案,就是采用了将ip与域名紧紧绑定在一起,每次公网变动的时候就将变动后的ip绑定到域名上,这样不管ip如何变化,都可以通过域名+端口的形式进行绑定。

  • 为什么不采用软路由或者其他路由上的ddns,或者站内有人写过的docker方式部署的ddns?

第一,软路由或者其他路由器部署ddns,具有不特定性,会因为不同路由器的设置方式不同而产生不同,而且相对来说可能对小白不是很友好,也不具有可复制性;第二,使用docker方式部署的ddns,在笔者自己动手试验后,并没有成功,可能是笔者自己的原因,但是为了保障结果的可复制性,还是最终决定给大家介绍这种稍显原始的方式。

  • 为什么使用阿里云而不是dnspot或者其他的域名服务商?

一方面,笔者自己的云服务器以及其他服务基本采用的都是阿里的方案,便于统一的维护,因此域名解析服务还是采用的阿里的;另一方面,由于腾讯对于英雄联盟皮肤的定价问题,除了微信这种不得不使用的软件,基本上能不用腾讯就不用腾讯的,这是个人偏好问题。最后,还不是因为其他的没有去研究过,我不会嘛。

  • 为什么使用chronos?

因为chronos是一个可视化的界面来运行python,操作上面足够简便。当然,如果有一定linux和docker基础的,也可以通过直接使用docker部署py脚本加crontab定时运行的方式来实现功能。但是,考虑到读者的水平不一,本文尽量以一种大家能够看的懂最简便的方式来实现功能,保持可复制性。

2 准备工作

一条具有公网IP的宽带,一般只有电信和联通可以提供,具体的还得去问一下当地的服务商,其次就是需要一个域名,一个很便宜的就行了,基本上十块钱左右一年的有一大把。

除了域名之外,还需要知道的就是阿里云的accessID与access sercet,具体可以参考站内这篇文章。

如果想在基本功能之上,加上一个变动ip即通知到你的微信,那么还需要的就是企业微信的AgentId、Secret、CompanyId三个参数,参照笔者之前这篇文章进行获取。

3 chronos的安装

这里还是需要重申一下,需要一台支持docker的设备,可以是捡垃圾来的设备,也可以是nas。但是,为了维持可复制性,还是推荐x86架构的设备,因为笔者在自己刷了armbian的玩客云上面试过,确实无法部署成功,不知道S905芯片的设备或者rk3399的设备是否可以支持,值友们如果有试过的可以告知一声。

此处默认已经安装好了docker,输入以下代码:

docker run -p 5000:5000 -v /mnt/docker/chronos:/chronos simsemand/chronos

待运行成功且没有报错,输入ip:5000即可进入头图中的页面,这样就代表部署成功了。

4 python部分的实现

这里想说明一下的是,这里想通过功能分解的方式进行展示。有些功能并不是必要,如微信推送公网ip的变动。这一部分如果不需要,那么就可以删掉对应的部分。作者最后准备给上两个版本的代码,供大家下载使用。

4.1 公网IP的获取

import os

ipv4=os.popen("curl ifconfig.me").read()

4.2 推送消息到微信

设置方面还是参照笔者之前的那篇文章,以下仅贴出代码。需要替换的部分就是你自己的AgentId、Secret、CompanyId。这一部分内容来源于网上,由于已经有现成的轮子,就不再重复造轮子了。

    def send2wechat(self,message):

        AgentId = ''

        Secret = ''

        CompanyId = ''

        # 通行密钥

        ACCESS_TOKEN = None

        # 如果本地保存的有通行密钥且时间不超过两小时,就用本地的通行密钥

        if os.path.exists('ACCESS_TOKEN.txt'):

            txt_last_edit_time = os.stat('ACCESS_TOKEN.txt').st_mtime

            now_time = time.time()

            if now_time - txt_last_edit_time < 7200:  # 官方说通行密钥2小时刷新

                with open('ACCESS_TOKEN.txt', 'r') as f:

                    ACCESS_TOKEN = f.read()

                    # print(ACCESS_TOKEN)

        # 如果不存在本地通行密钥,通过企业ID和应用Secret获取

        if not ACCESS_TOKEN:

            r = requests.post(

                f'https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid={CompanyId}&corpsecret={Secret}').json()

            ACCESS_TOKEN = r["access_token"]

            # print(ACCESS_TOKEN)

            # 保存通行密钥到本地ACCESS_TOKEN.txt

            with open('ACCESS_TOKEN.txt', 'w', encoding='utf-8') as f:

                f.write(ACCESS_TOKEN)

        # 要发送的信息格式

        data = {

            "touser": "@all",

            "msgtype": "text",

            "agentid": f"{AgentId}",

            "text": {"content": f"{message}"}

        }

        # 字典转成json,不然会报错

        data = json.dumps(data)

        # 发送消息

        r = requests.post(

            f'https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token={ACCESS_TOKEN}', data=data)

        # print(r.json())

4.3 汇总

关于域名解析部分的代码也是来源自网络,经笔者修改后如下所示。

需要注意的是,需要填入的是access_key_id、access_key_secret、domain 、name_ipv4,前两个即所获得的阿里云密钥,domian是你的域名,而name_ipv4则建议填入www,之后你的访问形式即www.abc.abc(即你的域名):端口号。

import json,requests,re,os

from urllib.request import urlopen

from aliyunsdkcore.client import AcsClient

from aliyunsdkalidns.request.v20150109.DescribeSubDomainRecordsRequest import DescribeSubDomainRecordsRequest

class Dnscontroller:

    # 阿里云个人中心获取Access_Key_Id和Access_Key_Secret

    access_key_id = ""

    access_key_secret = ""

    # 填写你的主域名

    domain = ""

    # 要进行ipv4 ddns解析的子域名(主机记录)

    name_ipv4 = ""

    # 解析记录类型,一般为A记录

    record_type = "A"

    # 区域

    region = "cn-hangzhou"

    def __init__(self):

        self.client = AcsClient(

            self.access_key_id,

            self.access_key_secret,

            self.region

        )

    def send2wechat(self,message):

        AgentId = ''

        Secret = ''

        CompanyId = ''

        # 通行密钥

        ACCESS_TOKEN = None

        # 如果本地保存的有通行密钥且时间不超过两小时,就用本地的通行密钥

        if os.path.exists('ACCESS_TOKEN.txt'):

            txt_last_edit_time = os.stat('ACCESS_TOKEN.txt').st_mtime

            now_time = time.time()

            if now_time - txt_last_edit_time < 7200:  # 官方说通行密钥2小时刷新

                with open('ACCESS_TOKEN.txt', 'r') as f:

                    ACCESS_TOKEN = f.read()

                    # print(ACCESS_TOKEN)

        # 如果不存在本地通行密钥,通过企业ID和应用Secret获取

        if not ACCESS_TOKEN:

            r = requests.post(

                f'https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid={CompanyId}&corpsecret={Secret}').json()

            ACCESS_TOKEN = r["access_token"]

            # print(ACCESS_TOKEN)

            # 保存通行密钥到本地ACCESS_TOKEN.txt

            with open('ACCESS_TOKEN.txt', 'w', encoding='utf-8') as f:

                f.write(ACCESS_TOKEN)

        # 要发送的信息格式

        data = {

            "touser": "@all",

            "msgtype": "text",

            "agentid": f"{AgentId}",

            "text": {"content": f"{message}"}

        }

        # 字典转成json,不然会报错

        data = json.dumps(data)

        # 发送消息

        r = requests.post(

            f'https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token={ACCESS_TOKEN}', data=data)

        # print(r.json())

    # 添加新的域名解析记录

    def add(self, DomainName, RR, Type, Value):

        from aliyunsdkalidns.request.v20150109.AddDomainRecordRequest import AddDomainRecordRequest

        request = AddDomainRecordRequest()

        request.set_accept_format('json')

        request.set_DomainName(DomainName)

        request.set_RR(RR)

        request.set_Type(Type)

        request.set_Value(Value)

        response = self.client.do_action_with_exception(request)

    # 修改域名解析记录

    def update(self, RecordId, RR, Type, Value):

        from aliyunsdkalidns.request.v20150109.UpdateDomainRecordRequest import UpdateDomainRecordRequest

        request = UpdateDomainRecordRequest()

        request.set_accept_format('json')

        request.set_RecordId(RecordId)

        request.set_RR(RR)

        request.set_Type(Type)

        request.set_Value(Value)

        response = self.client.do_action_with_exception(request)

    # 获取公网IP并进行修改

    def Get_IPv4(self):

        request = DescribeSubDomainRecordsRequest()

        request.set_accept_format('json')

        request.set_DomainName(self.domain)

        request.set_SubDomain(self.name_ipv4 + '.' + self.domain)

        response = self.client.do_action_with_exception(request)  # 获取域名解析记录列表

        domain_list = json.loads(response)  # 将返回的JSON数据转化为Python能识别的

        # 获取IP

        ipv4=os.popen("curl ifconfig.me").read()

        if domain_list['TotalCount'] == 0:

            self.add(self.domain, self.name_ipv4, self.record_type, ipv4)

            print("新建域名解析成功")

        elif domain_list['TotalCount'] == 1:

            if domain_list['DomainRecords']['Record'][0]['Value'].strip() != ipv4.strip():

                self.send2wechat('IP地址发生变更,现在的IP为{}'.format(ipv4))

                self.update(domain_list['DomainRecords']['Record'][0]['RecordId'], self.name_ipv4, self.record_type,

                            ipv4)

                print("修改域名解析成功")

            else:

                print("IPv4地址没变")


        elif domain_list['TotalCount'] > 1:

            # 删除所有解析过的记录,并重新添加新的解析记录

            from aliyunsdkalidns.request.v20150109.DeleteSubDomainRecordsRequest import DeleteSubDomainRecordsRequest

            request = DeleteSubDomainRecordsRequest()

            request.set_accept_format('json')

            request.set_DomainName(self.domain)

            request.set_RR(self.name_ipv4)

            response = self.client.do_action_with_exception(request)

            self.add(self.domain, self.name_ipv4, self.record_type, ipv4)

            print("修改域名解析成功")

if __name__ == "__main__":

    Dnscontroller().Get_IPv4()

关于代码部分,本文代码填入对应信息之后保存即可

5 chronos的设置

完成了上面的步骤之后,后面就到了chronos的设置部分了

新建脚本


填入需要的依赖:

aliyun-python-sdk-core==2.13.36

aliyun-python-sdk-domain==3.14.7

aliyun-python-sdk-alidns==2.6.32

requests==2.25.1

点击保存,然后点击安装依赖

粘贴修改后的脚本,然后保存,运行:

在这个下面会显示运行结果,可以点开查看一下是否运行成功

设置间隔运行

这个根据自己的需要来进行,笔者填入的是每隔一分钟检查一遍公网ip是否发生变动

最后,点击enable和execute,就可以不用管它了,你的服务器就会勤勤恳恳的每分钟给你检查一次,如果有变动的话就会自行更改。

6 总结

本文到此结束,希望大家使用愉快!后面可能主要精力想更新一点obsidian的内容,还希望大家多多支持哇。如果有什么想看的docker应用或者想实现的功能,也可以留言告知,能力范围内的一定安排!


","force_purephv":"0","gnid":"9240aa597807e3606","img_data":[{"flag":2,"img":[{"desc":"","height":"283","title":"","url":"https://p0.ssl.img.360kuai.com/t01ce4775afef9e40dd.jpg","width":"600"},{"desc":"","height":"283","title":"","url":"https://p0.ssl.img.360kuai.com/t011937f481cb7d09a0.jpg","width":"600"},{"desc":"","height":"283","title":"","url":"https://p0.ssl.img.360kuai.com/t01972f77975734e37c.jpg","width":"600"},{"desc":"","height":"283","title":"","url":"https://p0.ssl.img.360kuai.com/t01a046473af0df2c74.jpg","width":"600"}]}],"original":0,"pat":"art_src_1,fts0,sts0","powerby":"hbase","pub_time":1665223743000,"pure":"","rawurl":"http://zm.news.so.com/27ccb057420274189097b85a8f515f8c","redirect":0,"rptid":"0af11b2b472cadf4","s":"t","src":"什么值得买","tag":[],"title":"捡垃圾之后怎么玩? 篇二:如何借助Docker和python实现DDNS

袁华霭4908编写python 1.从键盘输入a,b,c三个变量的值,输出其中的最大者. -
能贝剂15851696096 ______ 1 2 3 4 a=int(input('please input first number a:')) b=int(input('please input first number b:')) c=int(input('please input first number c:')) print(max(a,b,c))

袁华霭4908Ulipad写python输入遇到问题了,总是把数据全输进去,才会有显示.是编辑器的问题吗,新手求指点啊 -
能贝剂15851696096 ______ 按菜单“python-->设置参数...”,在参数窗口中,在Parameters处填入: -u(负U)

袁华霭4908Python IDLE中如何设置命令行参数 .使用sys.argv[1]每次都提示IndexError: list index out of range -
能贝剂15851696096 ______ 因为在运行python脚本的时候你没在后面添加一个值.sys.argv[1]意思是取位置第二的参数.位置第一的是py名字,第二的参数你没有输入,所以取不到,所以报错out of range.你执行的时候一般是这样的:python xxx.py A 其中xxx是程序名字,即sys.argv[0]的位置.A是参数,即sys.argv[1]取的位置.必须有这个A才行,要不然sys.argv[1]取不到值肯定报错

袁华霭4908用python.输入a,b,c三个变量的值,输出其中的最大者的程序 -
能贝剂15851696096 ______ 1 2 3 4 5 6 #!/usr/bin/env python a=int(raw_input('input a:')) b=int(raw_input('input b:')) c=int(raw_input('input c:')) res=max(a,b,c) print'Max:',res 保存为check.py 执行: 1 2 3 4 5 [root@localhost python]# python check.py input a:10 input b:20 input c:30 Max: 30

袁华霭4908用python设计程序输入n个数,并计算平均值和最小值 -
能贝剂15851696096 ______ #include int main() {int x,i,n,min; printf("有几个数据:"); scanf("%d",&n); printf("请输入%d个数据:\n"); scanf("%d",&x); min=x; for(i=2;i

袁华霭4908用python编写脚本程序,实现用户输入3个整数,放入列表,并输出最小值 -
能贝剂15851696096 ______ list1 = input("请输入3个以空格为间隔的整数:").split() """以空格进行分割,删去字符串中的空格,剩下的元素以列表形式返回""" print("最小值为:",min(list1)) #利用内置函数min()返回最小值

袁华霭4908win10怎么设置python环境变量 -
能贝剂15851696096 ______ 在桌面上,输入快捷键“Win+X”,打开功能窗口,这时会在屏幕左下角出现一个弹窗,选择“控制面板”. 2 完成后会看到如下界面,选择“系统与安全“,如图. 3 进入“系统与安全”界面后,点击“系统”,如图. 4 完成后,单击“...

袁华霭4908BIOS设置里no execute mode mem protection什么意思,有ENABLE,DISABLE两个选项 -
能贝剂15851696096 ______ No-Execute Memory Protect是出现在英特尔平台BIOS的设置选项.中文译文为:不可执行内存保护. 是在内存中的某些关键段关闭执行权限,以防病毒恶意攻击. 由于其对内存的某些关键段进行权限限制,因此在超频过程中会影响超频的结果.所以请在正式超频之前将此选项关闭ENABLE是允许此项功能DISABLE是不允许此项功能

袁华霭4908usb及DOS密码设置与解除屏闭USB接口,就是在插入U盘时不显
能贝剂15851696096 ______ 一、屏蔽usb接口 一切为了安全——禁用USB设备 通过修改BIOS设置,可以直接屏... 温柔一刀:修改注册表停用USB驱动 在“开始”/“运行”中输入“Regedit”,按回车...

袁华霭4908怎么用python一次性修改所有键对应的值 -
能贝剂15851696096 ______ 1、说明: python中怎么改变一个字典的对应键的值很简单,直接赋值即可. 2、代码: dic = {'key': 100} print(dic['key']) dic['key'] = 200 #修改字典的对应键的值 print(dic['key']) 3、输出结果: 100 200 4、其它说明: 如果检测键值是否在字典中可以使用如下代码: if 'newkey' in dic: print(dic['newkey']) else: print('字典中不存在newkey键')

(编辑:自媒体)
关于我们 | 客户服务 | 服务条款 | 联系我们 | 免责声明 | 网站地图 @ 白云都 2024