zoukankan      html  css  js  c++  java
  • Python脚本批量修改服务器密码

    搭建环境

    centos 7.4

    使用脚本

    python
    批量修改connect用户的密码
    生成密码为随机密码 保存为xls文档
     
    passwd_chang
    
    #!/usr/bin/env python
    # -*- coding: utf-8 -*-
    import random
    import string,os
    import pexpect
    import xlrd,xlwt
    from xlwt import Style
    from xlutils.copy import copy
     
    def passwd_creat():
        salt = ''.join(random.sample(string.ascii_letters + string.digits, 8))
        return salt
     
    def passwd_change(userip, oldpasswd, newpasswd):
        child = pexpect.spawn('ssh connect@'+userip)                 ###connect 用户可改root
        fout = file('/home/shell/passwd/newpasslog.txt','a')            ##定义日志文件,
        child.logfile = fout
        index = child.expect(['password:','continue connecting (yes/no)?'])
        if index == 0:
            child.sendline(oldpasswd)
        elif index == 1:
            child.sendline('yes')
            child.expect('password:')
            child.sendline(oldpasswd)
        child.expect('$')
        child.sendline('sudo -i')
        child.expect('#')
        child.sendline('echo '+newpasswd+' | passwd --stdin connect')   ### connect 用户可改root
        child.expect('#')
        child.sendline('exit')
     
    def open_excel(passwdfile):
        data = xlrd.open_workbook(passwdfile)
        return data
     
    def get_coldata(passwdfile,sheet_name,num):
        data = open_excel(passwdfile)
        table = data.sheet_by_name(sheet_name)
        coldata = table.row_values(num)
        return coldata
     
    def get_rownum(passwdfile,sheet_name):
        data = open_excel(passwdfile)
        table = data.sheet_by_name(sheet_name)
        rowsNum = table.nrows  #获取总行数
        colsNum = table.ncols   #获取总列数
        return rowsNum,colsNum
     
    def add_newpwd(row, col, str):
        rb = xlrd.open_workbook(passwdfile, formatting_info=True)
        wb = copy(rb)
        ws = wb.get_sheet(0)
        ws.write(row, col, str)
        wb.save(passwdfile)
     
     
    if __name__ == "__main__":
        passwdfile = "/home/shell/passwd/newpasswd.xls"     #文档读取输出路径
        sheet_name = "Sheet1"
        rowsNum, colsNum = get_rownum(passwdfile,sheet_name)
        add_newpwd(0,colsNum,'newpasswd')
        for i in range(1,rowsNum):
            newpasswd = passwd_creat()
            coldata = get_coldata(passwdfile,sheet_name,i)
            passwd_change(coldata[0], coldata[1], newpasswd)
            add_newpwd(i,colsNum,newpasswd)
     

    1. 上传脚本,以及脚本需要的模块

     2.安装所需要的模块。

    2.1 解压gz包。
    2.2 cd到解压文件目录下
    2.3 执行脚本安装模块
    目录下的所有gz包都要安装过程略过

    3.执行脚本测试实验。

    3.1创建一个connect用户并设置密码。并登陆测试。
     
    3.2创建文档(文档名需要和脚本里的名称一样)
    3.3上传文档到定义的路径下
     
    3.4执行脚本测试
    3.5
    sz下载表格查看密码
     
    3.6 使用新密码登陆测试
     
     
  • 相关阅读:
    Mongodb 的ORM框架 Morphia之注解
    Redis主从集群及哨兵模式
    Dubbo
    Zookeeper
    使用Dockerfile自定义一个包含centos,tomcat的镜像
    linux/centOS 下安装 ngnix
    Session共享
    Linux安装jdk.18和tomcat8
    MongoDB集群的搭建
    多态--方法重写的三个要点
  • 原文地址:https://www.cnblogs.com/xuewenlong/p/12807854.html
Copyright © 2011-2022 走看看