python批量修改ssh密码_paramiko ssh密码过期 怎么修改

117 阅读2分钟

由于工作需要本文主结合了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)


现在能在网上找到很多很多的学习资源,有免费的也有收费的,当我拿到1套比较全的学习资源之前,我并没着急去看第1节,我而是去审视这套资源是否值得学习,有时候也会去问一些学长的意见,如果可以之后,我会对这套学习资源做1个学习计划,我的学习计划主要包括规划图和学习进度表。



分享给大家这份我薅到的免费视频资料,质量还不错,大家可以跟着学习

![](https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/e6c49c842ddb474ab0335db2f0289741~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3NTc5MjMwMTY3MDI=:q75.awebp?rk3s=f64ab15b&x-expires=1771413605&x-signature=cR9mkkDA9xjxwgKToQNvbB6SU%2FY%3D)



**了解详情:https://docs.qq.com/doc/DSnl3ZGlhT1RDaVhV**