《云计算全栈》-python篇:python编写创建用户脚本

3 案例3:创建用户
3.1 问题

创建adduser.py文件,实现以下目标:

编写一个程序,实现创建用户的功能
提示用户输入用户名
随机生成8位密码
创建用户并设置密码
将用户相关信息写入指定文件

3.2 方案

创建add_user()函数,让函数具有创建用户、创建密码、将用户密码写入到指定文件三种方法,因此为函数设置3个参数,分别是用户名、密码及用户名密码存放文件,最终通过函数调用上传实参的方式,完成用户创建

1.利用subprocess.call函数运行用户创建命令

2.subprocess.call函数运行密码设置命令

3.用with语句将指定的文件以追加模式打开,这样打开代码块结束后文件会自动关闭,将用户密码用指定格式写入指定文件

4.调用add_user()函数时上传的用户名实参,是利用sys.argv[]参数,在命令行调用的时候由系统传递给程序,这个变量其实是一个List列表,用于保存命令行上的参数,argv[0] 一般是“被调用的脚本文件名或全路径”,argv[1]和以后就是传入的系统命令参数
3.3 步骤

实现此案例需要按照如下步骤进行。

步骤一:编写脚本

将randpass文件的代码以模块形式导入以下代码中,直接调用gen_pass()函数获取返回值(即获取随机生成的密码):

[root@localhost day04] # vim adduser.py
#!/usr/bin/env python3
import sys
import subprocess
from randpass import gen_pass 
def add_user(username, password, fname):
    info = """user information:
username: %s
password: %s
"""
    subprocess.call('useradd %s' % username, shell=True)
    subprocess.call(
        'echo %s | passwd --stdin %s' % (password, username),
        shell=True
    )                                                                                                           
    with open(fname, 'a') as fobj:
        fobj.write(info % (username, password))
if __name__ == '__main__':
    username = sys.argv[1]
    password = gen_pass()
    fname = '/tmp/users.txt'
    add_user(username, password, fname) 

步骤二:测试脚本执行

[root@localhost day04]# python3 adduser.py b c d 
更改用户 b 的密码 。
passwd:所有的身份验证令牌已经成功更新。
[root@localhost day04]# python3 adduser.py a c d 
useradd:用户“a”已存在
更改用户 a 的密码 。
passwd:所有的身份验证令牌已经成功更新。
[root@localhost day04]# cat /tmp/users.txt
user information:
username: a
password: hD31SmTS
user information:
username: b
password: DztS7ycn
user information:
username: a
password: f2iH0Znt
发布了275 篇原创文章 · 获赞 46 · 访问量 2万+

猜你喜欢

转载自blog.csdn.net/xie_qi_chao/article/details/104725983