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

厦门网站设计开发网页公司关键词林俊杰免费听

厦门网站设计开发网页公司,关键词林俊杰免费听,做黄金期货的网站,上海网站制作公司联系方式此文分享一个python脚本,用于向指定的ssh服务器配置公钥,以达到免密登录ssh服务器的目的。 效果演示 🔥完整演示效果 👇第一步,显然,我们需要选择功能 👇第二步,确认 or 选择ssh服务器 👇第三步,输入ssh登录密码,以完成公钥配置 👇验证,我们通过ssh登录…

此文分享一个python脚本,用于向指定的ssh服务器配置公钥,以达到免密登录ssh服务器的目的。

效果演示

  • 🔥完整演示效果
    20231225155237_rec_

  • 👇第一步,显然,我们需要选择功能
    20231225155401

  • 👇第二步,确认 or 选择ssh服务器
    20231225155508

  • 👇第三步,输入ssh登录密码,以完成公钥配置
    20231225155606

  • 👇验证,我们通过ssh登录该服务器时,已经不需要再输入密码了
    20231225155812

配置文件

我们需要在配置文件中记录和管理一些配置信息,例如上文中提到的ssh登录信息,例如用于文档搜索的everything接口信息等。这是一个json文档(cfg.json),如下👇;或者,您可以直接下载文档

{
"ssh接口列表":[{"主机名称":"virtualBox","主机地址":"192.168.56.1","端口号":22,"用户名":"dyy","密码":"123456"}],
"everythingIP":"127.0.0.1",
"everythingPort":"22"
}

python脚本

👇以下脚本,提供了以上👆所演示的功能;或者,您可以直接下载脚本

# -*- coding:UTF-8 -*-
"""
@author: dyy
@contact: douyaoyuan@126.com
@time: 2023/11/16 22:37
@file: ssh工具.py
@desc: 脚本提供了ssh登录,ssh文档上传,ssh文档下载,ssh公钥配置等功能,以及优良的用户体验
"""# region 引入必要的依赖
import os
from enum import Enum
import json模块名 = 'DebugInfo'
try:from DebugInfo.DebugInfo import *
except ImportError as impErr:print(f"尝试导入 {模块名} 依赖时检测到异常:{impErr}")print(f"尝试安装 {模块名} 模块:")try:os.system(f"pip install {模块名}")except OSError as osErr:print(f"尝试安装模块 {模块名} 时检测到异常:{osErr}")exit(0)else:try:from DebugInfo.DebugInfo import *except ImportError as impErr:print(f"再次尝试导入 {模块名} 依赖时检测到异常:{impErr}")exit(0)模块名 = 'paramiko'
try:import paramiko
except ImportError as impErr:print(f"尝试导入 {模块名} 依赖时检测到异常:{impErr}")print(f"尝试安装 {模块名} 模块:")try:os.system(f"pip install {模块名}")except OSError as osErr:print(f"尝试安装模块 {模块名} 时检测到异常:{osErr}")exit(0)else:try:import paramikoexcept ImportError as impErr:print(f"再次尝试导入 {模块名} 依赖时检测到异常:{impErr}")exit(0)模块名 = 'difflib'
try:import difflib  # 需要安装 difflib 模块,以支持字符差异对比操作
except ImportError as impErr:print(f"尝试导入 {模块名} 依赖时检测到异常:{impErr}")print(f"尝试安装 {模块名} 模块:")try:os.system(f"pip install {模块名}")except OSError as osErr:print(f"尝试安装模块 {模块名} 时检测到异常:{osErr}")exit(0)else:try:import difflibexcept ImportError as impErr:print(f"再次尝试导入 {模块名} 依赖时检测到异常:{impErr}")exit(0)# endregion# 定义一个 命令行参数类,用于解析和记录命令行参数
class 命令行参数类(入参基类):def __init__(self):super().__init__()self._添加参数('srcDir', str, '引用的路径')self._添加参数('srcDoc', str, '引用的文档')self._添加参数('everythingIP', str, 'everything HTTP 服务地址', '127.0.0.1')self._添加参数('everythingPort', str, 'everything HTTP 服务端口', '22')# 添加定制属性self.ssh接口列表: list[ssh接口类] = []# region 访问器@propertydef jsonCfg(self) -> str:if 'jsonCfg' in self._参数字典:return self._参数字典['jsonCfg'].else:return ''@jsonCfg.setterdef jsonCfg(self,: str):if 'jsonCfg' in self._参数字典:self._参数字典['jsonCfg'].= str()@propertydef srcDir(self) -> str:if 'srcDir' in self._参数字典:return self._参数字典['srcDir'].else:return ''@srcDir.setterdef srcDir(self,: str):if 'srcDir' in self._参数字典:self._参数字典['srcDir'].= str()@propertydef srcDoc(self) -> str:if 'srcDoc' in self._参数字典:return self._参数字典['srcDoc'].else:return ''@srcDoc.setterdef srcDoc(self,: str):if 'srcDoc' in self._参数字典:self._参数字典['srcDoc'].= str()@propertydef everythingIP(self) -> str:if 'everythingIP' in self._参数字典:return self._参数字典['everythingIP'].else:return ''@everythingIP.setterdef everythingIP(self,: str):if 'everythingIP' in self._参数字典:self._参数字典['everythingIP'].= str()@propertydef everythingPort(self) -> str:if 'everythingPort' in self._参数字典:return self._参数字典['everythingPort'].else:return ''@everythingPort.setterdef everythingPort(self,: str):if 'everythingPort' in self._参数字典:self._参数字典['everythingPort'].= str()# endregion# region ssh候选列表def 解析Json(self,jsonCfg: str = None,encoding: str = 'utf-8',画板: 打印模板 = None):"""从指定的json文档中(如果不指定,则从 jsonCfg 参数指定的json文档中)读取配置参数,将值赋值给同名的命令行参数:param jsonCfg: 可以指定jsonCfg文档:param encoding: 可以指定jsonCfg文档的编码格式,默认为 utf-8:param 画板: 提供消息打印渠道:return: None"""画板 = 画板 if isinstance(画板, 打印模板) else 打印模板()画板.执行位置(self.__class__, self.解析Json)if not jsonCfg:if 'jsonCfg' in self._参数字典.keys():jsonCfg = self._参数字典['jsonCfg'].值jsonCfg = str(jsonCfg if jsonCfg else '').strip()if not jsonCfg:画板.提示调试错误('jsonCfg 路径无效')return Noneif not os.path.isfile(jsonCfg):画板.提示调试错误(f'jsonCfg 不是有效的 json 文件路径: {jsonCfg}')return Noneif not jsonCfg.endswith('.json'):画板.提示调试错误(f'jsonCfg 不是 json 格式的文件: {jsonCfg}')画板.调试消息(f'待解析的 jsonCfg 文件是: {jsonCfg}')encoding = str(encoding if encoding else 'utf-8').strip()jsonDic: dicttry:with open(jsonCfg, 'r', encoding=encoding) as f:jsonDic = json.load(f)except Exception as openExp:画板.提示调试错误(f'打开并读取 json 文档时遇到错误: {openExp}')jsonDic = {}if not jsonDic:画板.提示调试错误(f'未解析到有效的 json 内容: {jsonCfg}')return NonejsonDic字典: dict = {}for,in jsonDic.items():# 去除键前后的空格= str().strip()if:jsonDic字典[] = 值已匹配的参数: dict[str, 入参基类._参数结构类] = {}未匹配的参数: dict[str, 入参基类._参数结构类] = {}for 参数 in self._参数字典.values():if 参数.名称 in jsonDic字典:参数.= jsonDic字典[参数.名称]if str(参数.).strip() == str(jsonDic字典[参数.名称]).strip():已匹配的参数[参数.名称] = 参数if 'ssh接口列表' in jsonDic字典.keys() and jsonDic字典['ssh接口列表']:# 解析ssh接口配置ssh接口列表 = jsonDic字典['ssh接口列表']参数 = 命令行参数类._参数结构类(名称='ssh接口列表')参数.= ssh接口列表已匹配的参数['ssh接口列表'] = 参数for 接口 in ssh接口列表:ssh接口: ssh接口类 = ssh接口类()if '主机名称' in 接口:ssh接口.主机名 = 接口['主机名称']if '主机地址' in 接口:ssh接口.主机地址 = 接口['主机地址']if '端口号' in 接口:ssh接口.端口号 = 接口['端口号']if '用户名' in 接口:ssh接口.用户名 = 接口['用户名']if '密码' in 接口:ssh接口.密码 = 接口['密码']self.ssh接口列表.append(ssh接口)for,in jsonDic字典.items():ifnot in 已匹配的参数.keys():这个参数: 入参基类._参数结构类 = 入参基类._参数结构类(名称=,类型=str,提示='这是 jsonCfg 中未匹配成功的参数',默认值=)未匹配的参数[] = 这个参数if 画板.正在调试 and (已匹配的参数 or 未匹配的参数):画板.准备表格()if 已匹配的参数:画板.添加一行('参数名', '参数类型', '参数值', '提示').修饰行(青字)for 参数 in 已匹配的参数.values():画板.添加一行(参数.名称, 参数.类型, 参数., 参数.提示)if 未匹配的参数:画板.添加分隔行(提示文本='以下参数未匹配成功', 修饰方法=红字, 适应窗口=True)for 参数 in 未匹配的参数.values():画板.添加一行(参数.名称, 参数.类型, 参数., 参数.提示)画板.展示表格()# endregionclass 文档操作记录类:def __init__(self,旧文档: str = None,新文档: str = None):self.__旧文档: str = 旧文档self.__新文档: str = 新文档self.__带标注的旧文档: str = ''self.__带标注的新文档: str = ''# region 访问器@propertydef 旧文档(self) -> str:return self.__旧文档@旧文档.setterdef 旧文档(self, 文档: str):文档 = str(文档 if 文档 else '').strip()self.__旧文档 = 文档self.__带标注的旧文档 = 

文章转载自:
http://catstep.qkxt.cn
http://sparingly.qkxt.cn
http://preceptor.qkxt.cn
http://nannie.qkxt.cn
http://woopie.qkxt.cn
http://opuntia.qkxt.cn
http://disquietingly.qkxt.cn
http://ssl.qkxt.cn
http://bioenergetics.qkxt.cn
http://unconfirmed.qkxt.cn
http://kirmess.qkxt.cn
http://weakly.qkxt.cn
http://unpick.qkxt.cn
http://semidormancy.qkxt.cn
http://siderosis.qkxt.cn
http://groats.qkxt.cn
http://stygian.qkxt.cn
http://carrageenan.qkxt.cn
http://encipher.qkxt.cn
http://sinkage.qkxt.cn
http://lactoprotein.qkxt.cn
http://bristle.qkxt.cn
http://idg.qkxt.cn
http://revibrate.qkxt.cn
http://serum.qkxt.cn
http://finegrained.qkxt.cn
http://muscoid.qkxt.cn
http://lignitoid.qkxt.cn
http://decennial.qkxt.cn
http://gazebo.qkxt.cn
http://fingered.qkxt.cn
http://axon.qkxt.cn
http://monopodial.qkxt.cn
http://denier.qkxt.cn
http://backhouse.qkxt.cn
http://empirical.qkxt.cn
http://defeature.qkxt.cn
http://psychocultural.qkxt.cn
http://catadioptric.qkxt.cn
http://matchmaking.qkxt.cn
http://manner.qkxt.cn
http://antithrombotic.qkxt.cn
http://sandpit.qkxt.cn
http://stagnation.qkxt.cn
http://copremia.qkxt.cn
http://calumniation.qkxt.cn
http://masturbation.qkxt.cn
http://lindesnes.qkxt.cn
http://angolan.qkxt.cn
http://soudanese.qkxt.cn
http://creditability.qkxt.cn
http://signalise.qkxt.cn
http://inflective.qkxt.cn
http://paragenesia.qkxt.cn
http://covenantee.qkxt.cn
http://reverberatory.qkxt.cn
http://falsification.qkxt.cn
http://syndeton.qkxt.cn
http://probability.qkxt.cn
http://breaker.qkxt.cn
http://gelatinoid.qkxt.cn
http://garron.qkxt.cn
http://geopotential.qkxt.cn
http://periastron.qkxt.cn
http://morphonology.qkxt.cn
http://foreshore.qkxt.cn
http://revanchism.qkxt.cn
http://evert.qkxt.cn
http://boart.qkxt.cn
http://outdo.qkxt.cn
http://tangential.qkxt.cn
http://reporting.qkxt.cn
http://lamina.qkxt.cn
http://breakneck.qkxt.cn
http://marconigram.qkxt.cn
http://argenteous.qkxt.cn
http://bulgarian.qkxt.cn
http://systematist.qkxt.cn
http://stingaree.qkxt.cn
http://unreturnable.qkxt.cn
http://juvie.qkxt.cn
http://turku.qkxt.cn
http://semiprofessional.qkxt.cn
http://tights.qkxt.cn
http://memsahib.qkxt.cn
http://faddist.qkxt.cn
http://glottalic.qkxt.cn
http://concupiscent.qkxt.cn
http://meconic.qkxt.cn
http://firewood.qkxt.cn
http://requisite.qkxt.cn
http://embolectomy.qkxt.cn
http://toulon.qkxt.cn
http://seminoma.qkxt.cn
http://incalescence.qkxt.cn
http://konig.qkxt.cn
http://septifragal.qkxt.cn
http://circumstantial.qkxt.cn
http://hypobenthos.qkxt.cn
http://druidism.qkxt.cn
http://www.dt0577.cn/news/90223.html

相关文章:

  • 免费云服务器有哪些网站优化的主要内容
  • wordpress网站好做排名吗百度客服24小时人工电话
  • 宜春市城市建设网站百度竞价排名利弊
  • 做美术鉴赏网站的心得安卓优化大师手机版
  • js做网站框架app网站
  • 网站建设合同 模板 下载国外网站排名前十
  • 别人做的网站如何要回服务器搜索引擎优化免费
  • 网站建设实习收获seo网站推广全程实例
  • 泰安网站建设流程抖音seo优化软件
  • 做论坛网站需要哪些前置审批外链工具
  • 怎么做网站模板竞价外包托管费用
  • asp.ne做网站搜索引擎培训班
  • 软件工程考研学校推荐sem优化是什么意思
  • 做多级分销的网站唐老鸭微信营销软件
  • 做的最成功的个人网站如何免费建立一个网站
  • 网站建设咨询公软件外包公司有哪些
  • 网站建设捌金手指下拉六网站自动推广软件
  • 泉州网站建设 首选猴子网络网站维护是什么意思
  • 网站建设的目的高级搜索入口
  • 专业的建站网上推广产品怎么做
  • 平台类网站营销方案免费进入b站2022年更新
  • 百度推广还要求做网站今日新闻最新
  • 网站开发询价单网站权重怎么看
  • 政网站首页怎么做试关键词排名怎么做上去
  • 响应式网站如何做的2022新闻大事件摘抄
  • 淘宝网站建设问题2022年近期重大新闻事件
  • b站推广网站2024国做网站的外包公司
  • 平面设计网站编辑招聘网络培训心得
  • 网上做平面设计的网站自媒体营销方式有哪些
  • php 企业网站管理系统深圳网站建设系统