当前位置: 首页 > news >正文

Python 解析JSON实现主机管理

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,它以易于阅读和编写的文本形式表示数据。JSON 是一种独立于编程语言的数据格式,因此在不同的编程语言中都有对应的解析器和生成器。JSON 格式的设计目标是易于理解、支持复杂数据结构和具有良好的可扩展性。

JSON 数据是以键值对的形式存在的,而且易于阅读和编写。以下是一个简单的 JSON 示例:

{"name": "John Doe","age": 30,"city": "New York","isStudent": false,"grades": [95, 88, 75, 92],"address": {"street": "123 Main St","zipCode": "10001"}
}

在这个例子中,JSON 对象包含了一些属性,包括字符串、数字、布尔值、数组和嵌套的对象。

  • "name": "John Doe":字符串键值对。
  • "age": 30:数字键值对。
  • "city": "New York":字符串键值对。
  • "isStudent": false:布尔键值对。
  • "grades": [95, 88, 75, 92]:数组键值对。
  • "address": {...}:嵌套对象。

在实际应用中,JSON 数据通常用于前后端之间的数据交换,或者配置文件的存储。各种编程语言都提供了处理 JSON数据的库或模块。

很早之前大概是两年前,当时为了实现批量管理SSH账号密码并实现自动巡检功能,写过一个简单的命令行工具,通过使用JSON实现对特定主机账号密码与组的管理,如下代码,通过定义AdminDataBase()类,传如数据库文件名database.json实现对特定JSON文件的增删改查功能,在编写该案例后我对JSON的使用变得更加深刻了。

# -*- coding: utf-8 -*-
import os,jsonclass AdminDataBase(object):def __init__(self, database_path):self.database_path = database_path# 判断数据库文件是否存在,不存则则创建一个.def InitDatabase(self):if os.path.exists(self.database_path) != None :init_database = \{"HostList": [["1000", "127.0.0.1", "username", "password", "22"]],"HostGroup": [{"DefaultGroup": ["1000"]}, ],}with open(self.database_path, "w", encoding="utf-8") as fp:fp.write(json.dumps(init_database))print("[+] {} 结构已被初始化.".format(self.database_path))# table 接收一个列表名,根据列表名输出列表中的数据def ShowHostList(self):with open(self.database_path, "r", encoding="utf-8") as Read_Pointer:load_json = json.loads(Read_Pointer.read())base = load_json.get("HostList")print("-" * 80)print("UUID \t 主机地址 \t\t\t 登录用户 \t\t 登录密码 \t 端口")print("-" * 80)for each in range(0, len(base)):print("{0:4} \t {1:15} \t {2:10} \t {3:10} \t {4:10}".format(base[each][0], base[each][1], base[each][2], base[each][3], base[each][4]))print()# 在原来的基础上添加一台新的主机,添加到HostList表中def AddHost(self, uuid, address, username, password, port):with open(self.database_path, "r", encoding="utf-8") as Read_Pointer:# 读取 database.json 中的数据到内存中load_json = json.loads(Read_Pointer.read())# 先读入内存,修改后全部替换进去host_list = load_json.get("HostList")# 获取到最后一次循环的元素列表for each in range(len(host_list) - 1, len(host_list)):# 判断如果UUID不重复则添加,否则跳过添加if (host_list[each][0] != uuid):host_list.append([uuid, address, username, password, port])load_json["HostList"] = host_list# 最后再次将改好的数据,回写到文件保存with open(self.database_path, "w", encoding="utf-8") as Write_Pointer:dump_json = json.dumps(load_json)Write_Pointer.write(dump_json)print("[+] UUID {} 添加成功.".format(uuid))else:print("[-] UUID {} 列表中存在,添加失败.".format(uuid))return 0# 根据传入UUID号修改特定主机数据def ModifyHost(self,uuid,modify_address,modify_username,modify_password,modify_port):with open(self.database_path, "r", encoding="utf-8") as Read_Pointer:# 读取 database.json 中的数据到内存中load_json = json.loads(Read_Pointer.read())host_list = load_json.get("HostList")# 根据uuid寻找一维数组的下标位置index = -1for index, value in enumerate(host_list):if value[0] == uuid:print("[*] 已找到UUID {} 所在下标为 {}".format(uuid,index))breakelse:index = -1# 判断是否找到了,找到了则修改if index != -1:# 修改指定下标数值,并将修改后的数据放入原始JSON文件中host_list[index] = [uuid,modify_address,modify_username,modify_password,modify_port]load_json["HostList"] = host_list# 最后再次将改好的数据,回写到文件保存with open(self.database_path, "w", encoding="utf-8") as Write_Pointer:dump_json = json.dumps(load_json)Write_Pointer.write(dump_json)print("[+] UUID {} 修改完成.".format(uuid))return 0else:print("[-] UUID {} 不存在.".format(uuid))return 0# 根据传入的UUID号删除主机数据,先删除所对的组中的数据,然后在删除主机数据def DeleteHost(self,uuid):with open(self.database_path, "r", encoding="utf-8") as Read_Pointer:load_json = json.loads(Read_Pointer.read())host_group = load_json.get("HostGroup")# 首先在HostGroup中寻找并弹出相应UUIDfor each in range(0,len(host_group)):try:# 循环每个字典for k,v in host_group[each].items():# 判断UUID是否存在于每个字典中if v.count(uuid) != 0:# 移除并放入原始JSON中v.remove(uuid)load_json["HostGroup"] = v# 最后再次将改好的数据,回写到文件保存with open(self.database_path, "w", encoding="utf-8") as Write_Pointer:dump_json = json.dumps(load_json)Write_Pointer.write(dump_json)#print("[+] UUID {} 修改完成.".format(uuid))else:#print("[-] 当前组 {} 不能存在: {}".format(k,uuid))breakexcept Exception:print("[-] 当前组不能存在: {}".format(uuid))return 0# ----------------------------------------------# 其次寻找HostList中的数据并弹出host_list = load_json.get("HostList")try:# 根据uuid寻找一维数组的下标位置index = -1for index, value in enumerate(host_list):if value[0] == uuid:#print("[*] 已找到UUID {} 所在下标为 {}".format(uuid,index))breakelse:index = -1# 如果找到了,则直接根据下标弹出数据if index != -1:host_list.pop(index)load_json["HostList"] = host_list# 最后再次将改好的数据,回写到文件保存with open(self.database_path, "w", encoding="utf-8") as Write_Pointer:dump_json = json.dumps(load_json)Write_Pointer.write(dump_json)print("[+] UUID {} 主机: {} 已被移除.".format(uuid,host_list[index][1]))return 0except Exception:return 0# 向数据库中的HostGroup字段中添加一个主机组def AddHostGroup(self,add_group_name):with open(self.database_path, "r", encoding="utf-8") as Read_Pointer:load_json = json.loads( Read_Pointer.read() )group_obj = load_json.get("HostGroup")# 循环所有字典中的组for each in range(0, len(group_obj)):list_name = str(list(group_obj[each].keys())[0])# print("组节点: {}".format(list_name))# 循环判断表中是否存在指定的组名称if (list_name == add_group_name):print("[-] {} 存在于组中,无法继续添加.".format(list_name))return 0# 读取原始JSON文件,并构建回写参数tmp = {}tmp[add_group_name] = ["1000"]group_obj.append(tmp)# 回写添加主机组with open(self.database_path, "w", encoding="utf-8") as Write_Pointer:dump_json = json.dumps(load_json)Write_Pointer.write(dump_json)print("[+] 主机组 {} 已添加".format(add_group_name))# 在主机组中删除一个主机组def DeleteHostGroup(self,delete_group_name):with open(self.database_path, "r", encoding="utf-8") as Read_Pointer:load_json = json.loads( Read_Pointer.read() )group_obj = load_json.get("HostGroup")# 循环所有字典中的组for each in range(0, len(group_obj)):list_name = str(list(group_obj[each].keys())[0])# 循环判断表中是否存在指定的组名称if (list_name == delete_group_name):# 如果存在于组中,那我们就把他的each弹出列表group_obj.pop(each)# 将弹出后的列表再次写回JSON序列中with open(self.database_path, "w", encoding="utf-8") as Write_Pointer:dump_json = json.dumps(load_json)Write_Pointer.write(dump_json)print("[-] 主机组 {} 已移除.".format(delete_group_name))return 0print("[-] 主机组 {} 不存在.".format(delete_group_name))return 0# 向指定主机组中添加一个主机UUIDdef AddHostGroupOnUUID(self,group_name, uuid):with open(self.database_path, "r", encoding="utf-8") as Read_Pointer:load_json = json.loads( Read_Pointer.read() )group_obj = load_json.get("HostGroup")# 循环所有字典中的所有组for each in range(0, len(group_obj)):list_name = str(list(group_obj[each].keys())[0])# 如果找到了需要添加的组if (list_name == group_name):tmp = group_obj[each]# 获取到原始列表中的数据val = list(tmp.values())[0]# 判断输入的UUID号,是否在val列表中,不在则添加if str(uuid) not in val:val.append(str(uuid))# 将原始数据赋值到新的表中group_obj[each][list_name] = valelse:print("[-] UUID {} 已存在于 {} 主机组,添加失败.".format(uuid,group_name))return 0with open(self.database_path, "w", encoding="utf-8") as Write_Pointer:dump_json = json.dumps(load_json)Write_Pointer.write(dump_json)print("[+] 向主机组 {} 增加UUID {} 完成".format(group_name, uuid))return 0# 从指定主机组中删除一个指定的UUID号def DeleteHostGroupOnUUID(self,group_name, uuid):with open(self.database_path, "r", encoding="utf-8") as Read_Pointer:load_json =json.loads( Read_Pointer.read() )group_obj = load_json.get("HostGroup")# 循环所有字典中的组for each in range(0, len(group_obj)):list_name = str(list(group_obj[each].keys())[0])# 先来寻找到需要删除的主机组if (list_name == group_name):tmp = group_obj[each]# 寻找指定组中的指定列表val = list(tmp.values())[0]for x in range(0, len(val)):if (val[x] == uuid):print("[*] 搜索UUID: {} 索引值: {}".format(val[x], x))# 将要删除的UUID弹出列表val.pop(x)# 将弹出后的列表重新复制到主机组中group_obj[each][list_name] = val# 保存弹出后的列表到序列中with open(self.database_path, "w", encoding="utf-8") as write_fp:dump_json = json.dumps(load_json)write_fp.write(dump_json)print("[+] 从主机组 {} 弹出UUID {} 完成".format(group_name, uuid))return 0return 0# 输出所有主机组和全部节点信息def ShowAllGroup(self):with open(self.database_path, "r", encoding="utf-8") as Read_Pointer:load_json = json.loads( Read_Pointer.read() )group_obj = load_json.get("HostGroup")# 循环解析所有组,并解析出UUID所对应的主机地址等信息for each in range(0, len(group_obj)):for k, v in group_obj[each].items():print("-" * 140)print("主机组: {}".format(k))print("-" * 140)for each in range(0, len(v)):# print("--> UUID: {}".format(v[each]))# 循环判断,拿着组内UUID判断是否存在,如果存在则打印出主机详细信息base_obj = load_json.get("HostList")for x in range(0, len(base_obj)):if (v[each] == base_obj[x][0]):print("UUID: {0:6} \t 主机地址: {1:15} \t 主机账号: {2:15} \t 主机密码: {3:15} \t 端口: {4:5} \t".format(base_obj[x][0], base_obj[x][1], base_obj[x][2], base_obj[x][3],base_obj[x][4]))print("\n")# 只显示所有的主机组,包括组中主机数def ShowGroup(self):with open(self.database_path, "r", encoding="utf-8") as Read_Pointer:load_json = json.loads( Read_Pointer.read() )group_obj = load_json.get("HostGroup")print("-" * 80)print("{0:20} \t {1:5} \t {2:100}".format("主机组名","主机数","主机列表"))print("-" * 80)for each in range(0,len(group_obj)):for k,v in group_obj[each].items():print("{0:20} \t {1:5} \t {2:100}".format(k,str(len(v)), str(v)))print()return 0# 对指定的主机组进行Ping测试def PingGroup(self,group_name):with open(self.database_path, "r", encoding="utf-8") as Read_Pointer:load_json = json.loads( Read_Pointer.read() )group_obj = load_json.get("HostGroup")# 循环遍历主机列表for each in range(0, len(group_obj)):for k, v in group_obj[each].items():# 寻找主机组,找到后提取出所有的Valueif (k == group_name):item_list = v# 再循环,拿着v的值对base进行循环,提取出其中的用户名密码等for val in range(0, len(item_list)):# 得到循环列表:print(item_list[val])base_obj = load_json.get("HostList")# 循环base表中的计数器for base_count in range(0, len(base_obj)):# 判断base表中是否存在指定UUID,如果存在则输出其值if (base_obj[base_count][0] == item_list[val]):print("地址: {} \t 用户名: {} [ok]".format(base_obj[base_count][1],base_obj[base_count][2]))
if __name__ == "__main__":db = AdminDataBase("database.json")while True:try:cmd = str(input("[LyShell] # ")).split()if (cmd == ""):continueelif (cmd[0] == "exit"):exit(1)elif (cmd[0] == "clear"):os.system("cls")elif(cmd[0] == "Init"):db.InitDatabase()elif(cmd[0] == "ShowHostList"):db.ShowHostList()elif(cmd[0] == "ShowGroup"):db.ShowGroup()elif(cmd[0] == "ShowAllGroup"):db.ShowAllGroup()elif(cmd[0] == "AddHost" or cmd[0] == "ModifyHost"):if (len(cmd) - 1 >= 5):uuid = str(cmd[1]).split("=")[1]address = str(cmd[2]).split("=")[1]username = str(cmd[3]).split("=")[1]password = str(cmd[4]).split("=")[1]port = str(cmd[5]).split("=")[1]if cmd[0] == "AddHost":db.AddHost(uuid,address,username,password,port)elif cmd[0] == "ModifyHost":db.ModifyHost(uuid,address,username,password,port)elif(cmd[0] == "DeleteHost"):if(len(cmd)-1 >= 1):uuid = str(cmd[1]).split("=")[1]db.DeleteHost(uuid)elif(cmd[0] == "AddHostGroup"):group_name = str(cmd[1]).split("=")[1]db.AddHostGroup(group_name)elif(cmd[0] == "DeleteHostGroup"):group_name = str(cmd[1]).split("=")[1]db.DeleteHostGroup(group_name)elif(cmd[0] == "AddHostGroupOnUUID"):group_name = str(cmd[1]).split("=")[1]uuid = str(cmd[2]).split("=")[1]db.AddHostGroupOnUUID(group_name,uuid)elif(cmd[0] == "DelHostGroupOnUUID"):group_name = str(cmd[1]).split("=")[1]uuid = str(cmd[2]).split("=")[1]db.DeleteHostGroupOnUUID(group_name,uuid)elif(cmd[0] == "PingGroup"):group_name = str(cmd[1]).split("=")[1]db.PingGroup(group_name)elif (cmd[0] == "help"):print("By: LyShark")else:print("Not Command")except Exception:continue

使用案例

管理数据库(AdminDataBase)中的主机信息和主机分组信息。用户通过输入命令来执行不同的操作,如初始化数据库、显示主机列表、添加主机、修改主机信息、删除主机等。

以下是代码的主要功能和命令列表:

  • 初始化数据库:Init
  • 显示主机列表:ShowHostList
  • 显示主机分组:ShowGroup
  • 显示所有主机分组:ShowAllGroup
  • 添加主机:AddHost
  • 修改主机信息:ModifyHost
  • 删除主机:DeleteHost
  • 添加主机分组:AddHostGroup
  • 删除主机分组:DeleteHostGroup
  • 将主机添加到指定分组:AddHostGroupOnUUID
  • 从指定分组删除主机:DelHostGroupOnUUID
  • 按组执行 Ping 操作:PingGroup
  • 清屏:clear
  • 退出程序:exit
  • 帮助:help

Init

初次使用需要执行本命令,对数据库文件进行写出,如下所示;

ShowHostList

用于输出当前主机列表信息,如下图所示;

ShowGroup

用于输出当前主机组,如下图所示;

ShowAllGroup

用于输出所有的主机组以及组内的主机详细信息,如下图所示;

AddHost

添加一个新的主机记录,如下图所示;

ModifyHost

修改一个已有的主机记录,此处以UUID作为修改条件,如下图所示;

DeleteHost

根据一个UUID唯一标识,删除一个已存在的主机记录,如下图所示;

AddHostGroup

新增一个组名,默认会携带1000为初始主机,如下图所示;

DeleteHostGroup

删除一整个主机组,如下图所示;

AddHostGroupOnUUID

根据UUID号将特定主机添加到特定组内,如下图所示;

DelHostGroupOnUUID

根据主机组名,删除特定的UUID,如下图所示;

PingGroup

对特定主机组执行Ping功能测试,此处可以扩展,如下图所示;

总结部分

该案例只是用于学习如何灵活运用JSON实现数据的增删改查,其实在实战中意义不大,因为完全可以使用SQLite这类精简数据库,此案例只是本人为了熟悉JSON的增删改查而写的一个Demo工具。

相关文章:

Python 解析JSON实现主机管理

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,它以易于阅读和编写的文本形式表示数据。JSON 是一种独立于编程语言的数据格式,因此在不同的编程语言中都有对应的解析器和生成器。JSON 格式的设计目标是易于理解、…...

一体化污水处理设备材质怎么选

在环保意识日益增强的今天,污水处理设备成为城市建设过程中的重要环节。而选择合适的一体化污水处理设备材质,则成为了一项重要的决策。本文将从专业的角度出发,为您解析一体化污水处理设备材质的选取。 首先,一体化污水处理设备材…...

德国进口高速主轴电机在机器人上的应用及选型方案

随着机器人技术的日新月异,高速主轴电机在机器人领域的应用也日趋广泛。德国进口的SycoTec高速主轴电机,以其高转速、高精度、高刚度的特点,在机器人的切割、铣削、钻孔、去毛刺等加工应用中发挥着关键作用。 一、高速主轴电机的特点 SycoT…...

【软考中级——软件设计师】备战经验 笔记总结分享

考试成绩 我第一次备考是在2022 然后那时候取消了这次是第二次 靠前我一个月复习的看了以前的笔记 然后刷了七八道历年题目学习资料推荐 :zst——2021 b站链接自荐一下我的笔记 : 软考笔记专栏 视频确实很长 , 我的建议就是先看笔记 然后不会…...

146. LRU 缓存 --力扣 --JAVA

题目 请你设计并实现一个满足 LRU (最近最少使用) 缓存 约束的数据结构。 实现 LRUCache 类: LRUCache(int capacity) 以 正整数 作为容量 capacity 初始化 LRU 缓存int get(int key) 如果关键字 key 存在于缓存中,则返回关键字的值,否则返回…...

【C++】POCO学习总结(十):Poco::Util::Application(应用程序框架)

【C】郭老二博文之:C目录 1、Poco::Util::Application 应用框架 1.1 应用程序基本功能 Poco::Util::Application是POCO实现的的应用程序框架,支持功能如下: 命令行参数处理配置文件初始化和关机日志 1.2 命令行程序和守护进程 POCO支持…...

探索医学影像:如何通过ROI灰度直方图和ROI区域方格图揭示隐秘细节?

一、引言 医学影像是现代医学诊断的重要手段,其中nrrd文件格式作为一种常见的医学影像数据存储方式,被广泛应用于各种医学影像设备和软件中。这种文件格式具有丰富的元数据信息,可以精确记录影像的空间位置、方向和尺度等信息,对于…...

SASS基本语法总结

SASS是CSS预处理器,简单来说,SASS是比CSS更高一级的语言,它拥有CSS不具备的语法,比如if条件控制 SASS的预处理器 SASS是一种无法被浏览器直接执行的语言,我们需要通过预处理工具(可以理解为翻译工具&…...

【C++】简单工厂模式

2023年12月6日,周三下午 今天又学习了一次简单工厂模式 每多学习一次,都会加深对设计模式的理解 目录 什么是简单工厂模式简单工厂模式的优缺点举例说明 什么是简单工厂模式 简单工厂模式(Simple Factory Pattern)是一种创建型…...

el-tree数据量过大,造成浏览器卡死、崩溃

el-tree数据量过大,造成浏览器卡死、崩溃 场景:树形结构展示,数据超级多,超过万条,每次打开都会崩溃 我这里采用的是引入新的插件虚拟树,它是参照element-plus 中TreeV2改造vue2.x版本虚拟化树形控件&…...

2024 年甘肃省职业院校技能大赛中职组 电子与信息类“网络安全”赛项竞赛样题-A

2024 年甘肃省职业院校技能大赛中职组 电子与信息类“网络安全”赛项竞赛样题-A 目录 2024 年甘肃省职业院校技能大赛中职组 电子与信息类“网络安全”赛项竞赛样题-A 需要环境或者解析可以私信 (二)A 模块基础设施设置/安全加固(200 分&…...

面向LLM的App架构——业务维度

这是两篇面向LLM的大前端架构的第一篇,主要写我对LLM业务的认知以及由此推演出的大前端架构。由于我是客户端出身,所以主要以客户端角度来描述,并不影响对前端的适用性。 对LLM的认知 基于Google对AGI的论文,AGI或者LLM一定会朝…...

ElasticSearch之cat plugins API

命令样例如下: curl -X GET "https://localhost:9200/_cat/plugins?vtrue&pretty" --cacert $ES_HOME/config/certs/http_ca.crt -u "elastic:ohCxPHQBEs5*lo7F9"执行结果输出如下: name component version…...

【小米电脑管家】安装使用教程--非小米电脑

安装说明功能体验下载资源 Xiaomi HyperOS发布后,小米妙享电脑端独立版本也走向终点,最新的【小米电脑管家】将会内置妙享实现万物互联。那么本篇文章将分享非小米电脑用户如何绕过设备识别验证安装使用【小米电脑管家】实现万物互联 安装说明 1.解压文…...

视频讲解|基于多目标粒子群算法的配电网储能选址定容

1 主要内容 该视频为3012基于多目标粒子群算法的配电网储能选址定容matlab代码讲解内容,对应的资源下载链接为基于多目标粒子群算法的配电网储能选址定容,程序主要内容是:以系统节点电压水平(电网脆弱性)、网络损耗以…...

Android 13 - Media框架(22)- MediaCodec(三)

这一节开始我们将重新回到 MediaCodec 这一层来学习 buffer 的流转 status_t MediaCodec::dequeueOutputBuffer(size_t *index,size_t *offset,size_t *size,int64_t *presentationTimeUs,uint32_t *flags,int64_t timeoutUs) {sp<AMessage> msg new AMessage(kWhatDequ…...

git提交报错 fatal: LF would be replaced by CRLF in package-lock.json

报错 fatal: LF would be replaced by CRLF in package-lock.json 原因 git 在windows下&#xff0c;默认是CRLF作为换行符&#xff0c; git add 提交时&#xff0c;会检查文本中是否有LF 换行符&#xff08;linux系统&#xff09;&#xff0c;如果有则会告警&#xff0c; 所…...

卷积详解和并行卷积

ps&#xff1a;在 TensorFlow Keras 中&#xff0c;构建 Sequential 模型的正确方式是将层作为列表传递&#xff0c;而不是作为一系列单独的参数。 modelmodels.Sequential([layers&#xff0c;layers]) 而不是modelmodels.Sequential(layers&#xff0c;layers) 文章目录 卷积…...

c#生成二维码二维码中间添加定制LoGo

&#x1f680;介绍 &#x1f340;QRCoder是一个开源的.NET库&#xff0c;用于生成QR码&#xff08;Quick Response Code&#xff09;。这个库是用C#编写的&#xff0c;并且可以在.NET框架的各种版本上使用&#xff0c;包括.NET Framework, .NET Core, Mono, Xamarin等。QRCode…...

设计CPU功能的数字电路

实验目的(1)熟悉Multisim 电路仿真软件的操作界面和功能; (2)掌握逻辑电路综合设计,并采用仿真软件进行仿真。 实验内容1.试设计一个简易CPU功能的数字电路,实验至少要求采用4个74HC/HCT194作为4个存储单元(可以预先对存储单元存储数据),74HC283作为计算单元。请实现…...

在windows下编译libiconv库

libiconv是一个基于GNU协议的开源库,主要用于解决多语言编码处理转换等应用问题。在linux系统使用比较方便,但是windows下使用需要进行源码编译。这里我是使用libiconv的1.15版本源码和VS2019默认工具集配置进行编译。 首先需要用VS2019创建一个空项目,根目录为libiconv。 在…...

html,css,开发知识,调试知识

nget 方式提交 n使用 get 方式提交数据时&#xff0c;表单数据会附加在 URL 之后&#xff0c;由用户端直接发送至服务器&#xff0c;所以速度比 post 快&#xff0c;但缺点是数据长度不能太长。 npost 方式提交 n使用 post 时&#xff0c;表单数据是与 URL 分开发送的&#…...

Vulnerability: File Upload(Medium)--MYSQL注入

选择难度&#xff1a; 1.打开DVWA&#xff0c;并登录账户 2.选择模式&#xff0c;这里我们选择 文件上载的中级模式&#xff08;Medium&#xff09; 准备工作 1.在vsc里面写个一句话木马 2.下载BurpSuiteCommunit软件&#xff1a;百度搜索“burp suite官网” 下载地址www…...

短视频账号剪辑矩阵+无人直播系统源头开发

抖去推爆款视频生成器&#xff0c;通过短视频矩阵、无人直播&#xff0c;文案引流等&#xff0c;打造实体商家员工矩阵、用户矩阵、直播矩阵&#xff0c;辅助商家品牌曝光&#xff0c;团购转化等多功能赋能商家拓客引流。 短视频矩阵通俗来讲就是批量剪辑视频和批量发布视频&am…...

Python traceback模块:获取异常信息

异常对象提供了一个 with_traceback 用于处理异常的传播轨迹&#xff0c;查看异常的传播轨迹可追踪异常触发的源头&#xff0c;也可看到异常一路触发的轨迹。 下面示例显示了如何显示异常传播轨迹&#xff1a; class SelfException(Exception): passdef main():firstMethod() …...

单点登录方案调研与实现

作用 在一个系统登录后&#xff0c;其他系统也能共享该登录状态&#xff0c;无需重新登录。 演进 cookie → session → token →单点登录 Cookie 可以实现浏览器和服务器状态的记录&#xff0c;但Cookie会出现存储体积过大和可以在前后端修改的问题 Session 为了解决Co…...

HarmonyOS应用开发者基础认证考试(稳过)

判断题 ​​​​​​​ 1. Web组件对于所有的网页都可以使用zoom(factor: number)方法进行缩放。错误(False) 2. 每一个自定义组件都有自己的生命周期正确(True) 3. 每调用一次router.pushUrl()方法&#xff0c;默认情况下&#xff0c;页面栈数量会加1&#xff0c;页面栈支持的…...

日常开发日志

目录 1、idea开发服务启动的网页地址不显示前端样式&#xff1a; 2、java Date 与myibits 的空判断&#xff1a; 1、idea开发服务启动的网页地址不显示前端样式&#xff1a; idea开发时&#xff0c;tomcat启动的后端弹出的网页地址&#xff0c;呈现的网页没有样式&#xff0…...

【FMCW毫米波雷达设计 】 — FMCW波形

原书&#xff1a;FMCW Radar Design 1 引言 本章研究驱动FMCW雷达的主要波形:线性调频(LFM)波形。我们研究信号的行为及其性质。随后&#xff0c;本章讨论了匹配滤波理论&#xff0c;并研究了压缩这种波形的技术&#xff0c;特别是所谓的拉伸处理&#xff0c;它赋予FMCW雷达极…...

力扣labuladong一刷day35天

力扣labuladong一刷day35天 文章目录 力扣labuladong一刷day35天一、98. 验证二叉搜索树二、700. 二叉搜索树中的搜索三、701. 二叉搜索树中的插入操作四、450. 删除二叉搜索树中的节点 一、98. 验证二叉搜索树 题目链接&#xff1a;https://leetcode.cn/problems/validate-bi…...