Python-Flask:编写自动化连接demo脚本:v1.0.0

主函数:

# _*_ Coding : UTF-8 _*_
# @Time :  13:14
# @Author : YYZ
# @File : Flask
# @Project : Python_Project_爬虫
import jsonfrom flask import Flask,request,jsonify
import sshapi = Flask(__name__)# methods: 指定请求方式'''
接口解析参数host = host_info["host"]port = host_info["port"]service = host_info["service"]user = host_info["user"]pwd = host_info["pwd"]
'''
@api.route('/',methods=['POST'])
def install():# 请求方式为post时,可以使用 request.get_json()接收到JSON数据try:#host_info = request.get_json()  # 获取 POST 请求中的 JSON 数据host_info = request.get_data()# 如果得到的data是字符串格式,则需要用json.loads来变换成python格式,看个人需求host_info = json.loads(host_info)print(host_info)except Exception as e:return jsonify({'error': '请求数据失败'}), 400# 处理数据# 调用do_something_with_data函数来处理接收到的数据。try:connect = ssh.Sshclass(host_info["host"], host_info["user"], host_info["port"])  # 端口,用户,ssh端口connect.conn_by_pwd(host_info["pwd"])  # 输入密码,进行登录except Exception as e:return jsonify({'error': '连接失败'}), 888if  host_info["cmd"] :try:command_res = str(connect.exec_commond(host_info["cmd"]))    #执行命令print(command_res)except Exception as e:return jsonify({'error': '执行失败'}), 888if host_info["file-determine"] == "yes":try:file_res = connect.upload_file(host_info["local_path"],host_info["remote_path"],host_info["file_name"])print(host_info["file_name"]+str(file_res))except Exception as e:return jsonify({'error': '上传失败'}), 888return  "操作完成"if __name__ == '__main__':api.run(host='0.0.0.0', port=8080, debug=True)

Ssh连接部分:

import paramiko
import json
'''
ssh 连接对象
本对象提供密钥连接、命令执行、关闭连接
'''class Sshclass(object):# ip = ''# port = 22# username = ''# timeout = 0# ssh = Nonedef __init__(self,ip,username,port=22,timeout=30):'''初始化ssh对象:param ip: 主机IP:param username: 登录用户名:param port: ssh端口号:param timeout: 连接超时:return:'''self.ip = ipself.username = usernameself.timeout = timeoutself.port = port'''SSHClient作用类似于Linux的ssh命令,是对SSH会话的封装,该类封装了传输(Transport),通道(Channel)及SFTPClient建立的方法(open_sftp),通常用于执行远程命令。Paramiko中的几个基础名词:1、Channel:是一种类Socket,一种安全的SSH传输通道;2、Transport:是一种加密的会话,使用时会同步创建了一个加密的Tunnels(通道),这个Tunnels叫做Channel;3、Session:是client与Server保持连接的对象,用connect()/start_client()/start_server()开始会话。'''ssh = paramiko.SSHClient()#远程主机没有本地主机密钥或HostKeys对象时的连接方法,需要配置ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())self.ssh = sshdef conn_by_key(self,key):'''密钥连接:param key:  str rsa密钥路径:return:  ssh连接对象'''rsa_key = paramiko.RSAKey.from_private_key(key)self.ssh.connect(hostname=self.ip,port=self.port,username=self.username,pkey=rsa_key,timeout=self.timeout)if self.ssh:print('密钥连接成功')else:self.close()raise Exception('密钥连接失败')def conn_by_pwd(self,pwd):'''密码连接:param pwd: 登录密码:return:  ssh连接对象'''self.ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())self.ssh.connect(hostname=self.ip,port=self.port,username=self.username,password=pwd)if self.ssh:print('密码连接成功')else:self.close()raise Exception('密码连接失败')def exec_commond(self,command):'''命令控制:param commond: 命令:return: 返回结构'''if command:stdin, stdout, stderr = self.ssh.exec_command(command)return {"stdin":command,"stdout":stdout.read(),"stderr":stderr.read()}else:self.close()raise Exception("命令不能为空")def close(self):'''关闭当前连接:return:'''if self.ssh:self.ssh.close()else:raise Exception("ssh关闭连接失败,当前对象没有ssh连接。")def upload_file(self,local_path,remote_path,file_name):# sftp_link = paramiko.Transport(self.ip,self.port)# sftp_link.connect(username=self.username,password=pwd)# sftp = paramiko.SFTPClient.from_transport(sftp_link)sftp = self.ssh.open_sftp()try:sftp.put(local_path+"\\"+file_name, remote_path+"/"+file_name)#print("上传成功")return ("上传成功"), 200except Exception as e:return {'error': '上传失败'}, 888finally:sftp.close()self.close()if __name__ == '__main__':ssh = Sshclass('192.168.115.23','root', port=22)pwd = "123456"local_path = 'D:\PyChrom\Python_Flask\自动化接口--Flask'remote_path = "/opt"file_name = 'file.py'ssh.conn_by_pwd(pwd)#res = str(ssh.exec_commond("ls /"))#print(res)res = ssh.upload_file(local_path,remote_path,file_name)print(res)

接口调试

后续优化思路:

目前只是远程连接+文件上传,后续会继续优化

弄个公共的nfs,平常一些脚本和包会放到这个nfs里,脚本或包自动从nfs里拉,然后执行脚本,即可部署,包括多机部署。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/91877.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

TSM动作识别模型【详解】

文章目录 本文使用的是somethingv2数据集,解压后是如下形式; 由于该压缩数据进行了分卷操作,需要合并后才能进行解压。首先我们将下面4个json文件剪贴到其他文件夹,只保留00-19的文件,然后在该文件夹下打开cmd&#xf…

模块化CSS

1、什么是模块化CSS 模块化CSS是一种将CSS样式表的规则和样式定义封装到模块或组件级别的方法,以便于更好地管理、维护和组织样式代码。这种方法通过将样式与特定的HTML元素或组件相关联,提供了一种更具可维护性、可复用性和隔离性的方式来处理样式。简单…

机器人制作开源方案 | 四轴飞行器

1. 概述 基于探索者搭建的模块化四轴飞行器研究平台,采用独特的设计方式,可实现在室内完成对四轴飞行器、无人机等运动控制的原理研究,以及学习飞行控制的原理知识。 2. 组装 请按照下图进行机架的组装。 整体图 请解压文末资料中的 /软件/Mi…

【LeetCode热题100】--226.翻转二叉树

226.翻转二叉树 /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode() {}* TreeNode(int val) { this.val val; }* TreeNode(int val, TreeNode left, TreeNode right) {* …

【聊天系统的优化】RPC方式的优化

RPC方式的优化 聊天系统的中RPC的选择Jsonprotobufmsgpack 聊天系统的中RPC的选择 在RPC方式中,常用的三种方式:Json,protobuf,Msgback 设定一个简单的加和服务,客户端发送一个list给服务端,需要将list的…

QT的ui设计中改变样式表的用法

在QT的ui设计中,我们右键会弹出一个改变样式表的选项,很多人不知道这个是干什么的。 首先我们来看下具体的界面 首先我们说一下这个功能具体是干嘛的, 我们在设置很多控件在界面上之后,常常都是使用系统默认的样式,但是当有些时候为了美化界面我们需要对一些控件进行美化…

Kafka-Kerberos票据刷新问题

线上kafka使用了 kerberos 认证,每隔24小时,票据过期,无法自动续期,出现消息发送失败问题。 从日志可以发现会有如下报错: 2023-09-14 17:48:47,144 [kafka-kerberos-refresh-thread-kafka/hdp-1HADOOP.COM] [] WARN …

Kafka(一)使用Docker Compose安装单机Kafka以及Kafka UI

文章目录 Kafka中涉及到的术语Kafka镜像选择Kafka UI镜像选择Docker Compose文件Kafka配置项说明KRaft vs Zookeeper和KRaft有关的配置关于Controller和Broker的概念解释Listener的各种配置 Kafka UI配置项说明 测试Kafka集群Docker Compose示例配置 Kafka中涉及到的术语 对于…

面试必考精华版Leetcode236. 二叉树的最近公共祖先

题目: 代码(首刷看解析 10.1): class Solution { public:TreeNode* ansnullptr;bool FindSon(TreeNode* root,TreeNode* p,TreeNode* q){if(root nullptr) return false;bool lson FindSon(root->left,p,q);bool rson FindSon(root-&…

基于SpringBoot的课程答疑系统

目录 前言 一、技术栈 二、系统功能介绍 学生信息管理 科目类型管理 老师回答管理 我的收藏管理 学生问题 留言反馈 交流区 三、核心代码 1、登录模块 2、文件上传模块 3、代码封装 前言 随着信息互联网信息的飞速发展,无纸化作业变成了一种趋势&#x…

vSAN7.0更换硬盘步骤

更换容量盘 预先检查 查看故障硬盘 清单->集群->监控->vsan->skyline运行->物理磁盘->运维运行状况 检查数据同步状态 清单->集群->监控->vsan->重新同步对象,数值全为0表示未重建。 数据迁移检查 清单->集群->监控->…

Java实现word excel ppt模板渲染与导出及预览 LibreOffice jodconverter

Java Office 一、文档格式转换 文档格式转换是office操作中经常需要进行一个操作,例如将docx文档转换成pdf格式。 java在这方面有许多的操作方式,大致可以分为内部调用(无需要安装额外软件),外部调用(需…

数据结构--Trie字符串统计

1、“Trie树” 作用: 高效地存储和查找字符串集合的数据结构。 2、“Trie树” 存储字符串的形式如下: 用 “0” 来表示 “根节点(root)”。存入一个字符串时,会在字符串最后结尾的那个字符节点打上标记。比如&#x…

babel.config.js配置文件详解

文章目录 一、前言三、babel 详解四、拓展阅读 一、前言 项目开发阶段,使用可选链操作符 ?. 出现以下编译报错问题: 分析:由于可选链操作符 ?. 是ES2020(即ES11)中推出的新语法,允许我们不需要校验当前属…

FreeRTOS(以STM32F1系列为例子)

目录 任务管理任务函数任务控制块顶层任务状态创建任务xTaskCreatexTaskCreateStaticxTaskCreateRestricted 任务优先级和心跳设置心跳设置优先级概述vTaskPrioritySetuxTaskPriorityGet 非运行态扩充阻塞态vTaskDelay挂起状态vTaskSuspend就绪状态完整的状态转换图延迟函数vTa…

Spring Boot的自动装配中的@ConditionalOnBean条件装配注解在Spring启动过程中,是如何保证处理顺序靠后的

前言 为什么Spring Boot条件注解那么多,而标题中是ConditionalOnBean呢? 因为,相比之下我们用的比较多的条件装配注解也就是ConditionalOnClass、ConditionalOnBean了,而ConditionalOnClass对顺序并不敏感(说白了就是判…

《数据结构、算法与应用C++语言描述》-栈的应用-开关盒布线问题

开关盒布线问题 问题描述 在开关盒布线问题中,给定一个矩形布线区域,其外围有若干管脚。两个管脚之间通过布设一条金属线路来连接。这条金属线路称为电线,它被限制在矩形区域内。两条电线交叉会发生电流短路。因此,电线不许交叉…

根据GWAS数据估算样本量N和使用千人基因组填充maf的参考文献

https://github.com/GenomicSEM/GenomicSEM/wiki/2.1-Calculating-Sum-of-Effective-Sample-Size-and-Preparing-GWAS-Summary-Statistics

AI绘画本地部署Stable Diffusion web UI

AI绘画本地部署Stable Diffusion web UI 一 、项目介绍 A browser interface based on Gradio library for Stable Diffusion. 项目地址:GitHub - AUTOMATIC1111/stable-diffusion-webui: Stable Diffusion web UI 这是一个可以通过直接输入描述性文字文本来生成…

MD5 绕过第三式:ffifdyop

文章目录 参考环境推荐阅读雾现两个 PHP 文件表结构分析 雾散ASCII 编码二进制数据到 ASCII 文本的转化绕过原理ffifdyop绕过 ffifdyop 的批量化生产批量化生产注意事项细节一字之差运算符优先级 实际需要遵守的规则 生产机器 参考 项目描述搜索引擎Bing、GoogleAI 大模型文心…