金狮镖局 Design By www.egabc.com
由于工作需要本文主结合了excel表格,对表格中的ssh密码进行批量修改
以下是详细代码(python3):
''' 遇到问题没人解答?小编创建了一个Python学习交流QQ群:857662006 寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书! ''' #!/usr/bin/env python #-*-coding:utf-8-*- import paramiko import socket import pandas as pd def demo(Ip,user,old_password,new_password): # 建立一个sshclient对象 ssh = paramiko.SSHClient() # 允许将信任的主机自动加入到host_allow 列表,此方法必须放在connect方法的前面 ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) # 调用connect方法连接服务器 #如果远程执行命令错误信息是b'the input device is not a TTY\n' 去掉docker exec -it 中的t就好了 try: ssh.connect(hostname=Ip, port=22, username=user, password=old_password,timeout=5) #ubuntu修改密码两种方法 #方法一 # command1 = "echo '%s:%s' | chpasswd"%(user,new_password) # stdin, stdout, stderr = ssh.exec_command(command1) # out, err = stdout.read(), stderr.read() # if err != '': # print(err) # # else: # print(out) # # 关闭连接 # ssh.close() #方法二 command = "passwd %s" %(user) stdin, stdout, stderr = ssh.exec_command(command) #\n模拟回车 输两次密码 stdin.write(new_password + '\n' + new_password + '\n') out, err = stdout.read(), stderr.read() successful = 'password updated successfully' #print(out,err) if successful in str(err): print(Ip + " 密码修改成功!") else: print('\033[31m错误:\033[0m' + str(err)) print(Ip + " 密码修改失败!") # 关闭连接 ssh.close() except paramiko.ssh_exception.AuthenticationException as e: print(Ip + ' ' + '\033[31m账号密码错误!\033[0m') with open('nossh.txt','a') as f: f.write(Ip + '\n') except socket.timeout as e: print(Ip + ' ' + '\033[31m连接超时!\033[0m') with open('timeoutssh','a') as f: f.write(Ip + '\n') def Red_Excel(IP): import sys import time file = r'E:\xxx.xlsx' pd.set_option('display.max_columns', None) pd.set_option('display.max_colwidth', 1000) n = pd.read_excel(file,sheet_name='xxx') #表格中的sheet名 #print(n.values) #显示含某字段的特定行 n1 = (n.loc[n['IP']==IP]) if not n1.empty: n2 = n1.values ip = n2[0][1] user = n2[0][4] password_old = n2[0][5] password_new = n2[0][22] houtai = n2[0][16] print('IP:%s 账号:%s 旧密码:%s 是否后台:%s 新密码:%s' % (ip, user, password_old, houtai,password_new)) demo(ip,user,password_old,password_new) else: print('记录表无此IP!') if __name__ == "__main__": with open('ip.txt') as f: for i in f: ip = i.split('\n')[0] Red_Excel(ip)
此代码可以适当修改,进行单独的ssh密码修改。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
金狮镖局 Design By www.egabc.com
金狮镖局
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
金狮镖局 Design By www.egabc.com
暂无python批量修改ssh密码的实现的评论...
更新日志
2024年11月15日
2024年11月15日
- 永恒英文金曲精选4《TheBestOfEverlastingFavouritesVol.4》[WAV+CUE]
- 群星《国风超有戏 第9期》[320K/MP3][13.63MB]
- 群星《国风超有戏 第9期》[FLAC/分轨][72.56MB]
- P1X3L《P1X3L》[320K/MP3][143MB]
- 群星.2022-良辰好景知几何电视剧原声带【SONY】【FLAC分轨】
- 庾澄庆.1991-管不住自己【福茂】【WAV+CUE】
- 欧倩怡.2001-Cindy(EP)【华星】【WAV+CUE】
- P1X3L《P1X3L》[FLAC/分轨][791.28MB]
- 茵达INDAHKUS《茵 the Blue》[320K/MP3][33.49MB]
- 茵达INDAHKUS《茵 the Blue》[FLAC/分轨][147.57MB]
- 老虎鱼AnneClarkwithUllavanDaelenJustinCiuche-Borderland-HiRes-Files24bit88.2kHz
- 江玲2004-百合盛开2CD[歌林][WAV+CUE]
- 孙露《怕什么孤单3CD》深圳音像[WAV分轨]
- s14全球总决赛目前是什么结果 s14全球总决赛赛程结果图一览
- s2TPA夺冠五人名单都有谁 tpa战队s2夺冠队员名单一览