用户的添加与删除练习

-> 脚本1(if then)

思路:
1.条件测试, 脚本使用案例, 创建用户【交互式创建】
1.怎么交互式 read -p
2.接收到对应字符串怎么创建用户 useradd
3.用户是否存在,如果存在则不执行,如果不存在则执行

脚本实现:

#!/usr/bin/bash
read -p "Please input a username: " user
id $user &>/dev/null if [ $? -eq ]; then
echo "user $user already exists"
else
useradd $user
if [ $? -eq ];then
echo "$user is created."
fi
fi

-> 脚本2(创建用户+密码)

[root@jumpserver- scripts]# cat user.sh
#!/bin/bash #.判断用户输入是否为空
read -p "请输入要创建用户的数量 :" num
if [[ -z $num ]];then
echo "输入的用户名不能为空"
exit
fi #.判断用户输入的是否为数字
if [[ ! "$num" =~ ^[-]+$ ]];then
echo "你输入的不是数字"
exit
fi #.判断用户输入的是否为空
read -p "请输入要创建用户的名称 :" name
if [[ -z $name ]];then
echo "用户名不能为空值"
exit
fi #.判断用户输入的是否为数字
if [[ ! "$name" =~ ^[a-z]+$ ]];then
echo "你输入的不能是小写字母"
exit
fi #.遍历用户输入的数字
for i in $(seq $num);do
useradd $name$i # 创建用户
echo "" |passwd --stdin $name$i &>/dev/null #给新创建的用户设置密码123
echo "$name$i用户创建成功,密码为:123"
done

-> 脚本3(for)

[root@jumpserver- scripts]# cat useradd.sh
#!/usr/bin/bash for i in $(cat tt.txt)
do
id $i &>/dev/null
if [ $? -ne ];then
useradd $i
echo -e "\033[32m $i 用户创建成功... \033[0m "
else
echo -e "\033[31m $i 用户已经存在... \033[0m "
fi
done tt.txt 只是一个测试文件,可以随便写内容

-> 脚本4(while)

[root@jumpserver- scripts]# cat while_user.sh
#!/bin/bash while read user
do
id $user &>/dev/null
if [ $? -ne ];then
useradd $user
echo -e "\033[32m $user 用户创建成功... \033[0m "
else
echo -e "\033[31m $user 用户已经存在... \033[0m "
fi
done<user.txt

-> 脚本5 (while-添加指定用户和密码)

[root@jumpserver- scripts]# cat while_user_2.sh
#!/bin/bash while read test
do
user=$(echo $test | awk '{print $1}')
passwd=$(echo $test | awk '{print $2}') id $user &>/dev/null
if [ $? -eq ];then
echo "用户 $user 已经存在"
else
useradd $user && echo "$passwd" |passwd --stdin $user &>/dev/null
echo "用户 $user 创建成功。。密码是 $passwd"
fi
done<test.txt

test文件内容:

[root@jumpserver-70 scripts]# cat test.txt
zhuzhu 123
haha 234
hehe 345
[root@jumpserver-70 scripts]# sh while_user_2.sh  (实现的效果)
用户 zhuzhu 创建成功。。密码是 123
用户 haha 创建成功。。密码是 234
用户 hehe 创建成功。。密码是 345

  

-> 脚本6(随机创建用户和密码)

8.添加user_00->user_09 10个用户, 并且给他们设置一个随机密码, 密码要求10位包含大小写字母以及数字, 注意需要把每个用户的密码记录到一个日志文件中

[root@jumpserver- scripts]# cat user_random.sh
#!/bin/bash user=user_0 for i in {..}
do
user_add=$user$i
user_pass=$(openssl rand -base64 |sed 's#[^a-zA-Z0-9]##g'|cut -c1-) id $user_add &>/dev/null
if [ $? -eq ];then
echo "用户已经存在了"
else
useradd $user_add && echo "$user_pass" | passwd --stdin $user_add &>/dev/null
echo "$user_add 用已经创建成功,密码是 $user_pass"
echo "$user_add $user_pass" >>user_passwd.txt
fi
done echo "用户是: $username 密码是: $password" |tee -a /tmp/user.txt
也可以用漏斗的方式,一遍生成一边直接写入脚本

->实现效果

[root@jumpserver-70 scripts]# cat user_passwd.txt
user_00 +QuwBA1i06
user_01 4CrXFwP0ME
user_02 xVYV8uB7a6
user_03 4OA6cTB5pu
user_04 mj/4K48pYA
user_05 vq5ogC4FAX
user_06 xCszOnBEc1
user_07 ct4tHHcjNK
user_08 iwLxFI2Rfx
user_09 5/pYJRhoRK

-> 脚本7 (随机字符-批量添加)-面试题

10.写一个脚本,实现批量添加20个用户,用户名为user01-20,密码为用户名后面跟5个随机字符。

[root@jumpserver- zuoye]# cat 10_user_add.sh
#!/bin/bash for i in {..}
do
passwd=$( uuidgen | sed -r 's#[0-9-]+##g' | cut -c -)
user_pass=user$i$passwd
id user$i &>/dev/null if [ $? -eq ];then
echo "用户 user$i 已经存在。。。"
else
useradd user$i && echo "${user_pass}" | passwd --stdin user$i >>/dev/null
echo "用户 user$i 创建成功。。。"
fi
done

->批量删除用户脚本(不完善,仅作为练习参考)

[root@jumpserver- scripts]# cat del_user.sh
#!/usr/bin/bash
read -p "请输入你想要删除的用户名称:" name
read -p "请输入你想要删除的用户数量:" num if [[ ! $name =~ ^[a-Z]+$ ]];then
echo "输入错误,请输入字母"
exit
fi if [[ ! $num =~ ^[-]+$ ]];then
echo "输入纯数字"
exit
fi echo "你要删除的用户名称是: $name
你要删除的用户数量是多少个: $num" read -p "你确定你要删除? " ready for i in $(seq $num);do username=$name$i case $ready in y|Y|Yes|YES) id $username &>/dev/null
if [ $? -eq ];then
echo "正在删除${username}......"
userdel -r $username
echo "删除完成"
else
echo "${username}不存在,无法删除"
fi
;; n|No|NO|no) echo "你选择退出,不会删除任何用户....."
exit
;;
*)
echo "您输入错误...."
exit
;;
esac
done

  

shell用户管理->的更多相关文章

  1. 【shell 练习4】编写Shell用户管理脚本(二)

    一.创建.删除.查看用户,随机生成八位数密码 #!/bin/bash #Author:yanglt #!/bin/bash #Author:yanglt #Blog:https://www.cnblo ...

  2. linux 用户管理

    linux 用户管理 创建一个用户 foo 这个用户只能在/home/foo 上面增加删除文件, foo 不能在其他目录加减文件 useradd -d /home/foo -m foo [root@] ...

  3. mongodb的用户管理及安全认证

    1.确认mongodb的版本 > use admin switched to db admin > db.runCommand({}) { "version" : &q ...

  4. linux 用户管理(一)

    本节内容梗概: 1.用户管理配置文件 2.用户管理命令 3.用户组管理命令 4.批量添加用户 5.用户授权 学东西先讲原理,所以从配置文件入手 1.用户信息文件  /etc/passwd 存放了用户的 ...

  5. 第3章 Linux常用命令(4)_帮助、用户管理和解压缩命令

    4. 帮助命令 4.1 获取帮助信息:man (1)man命令 命令名称 man(英语原义:manual) 命令所在路径 usr/bin/man 执行权限 所有用户 语法 man [级别] [命令或配 ...

  6. Linux用户管理.md

    用户与组的概念 linux多用户,多任务的特性 Linux是一个真实的.完整的多用户多任务操作系统,多用户多任务就是可以在系统上建立多个用户,而多个用户可以在同一时间内登录同一个系统执行各自不同的任务 ...

  7. centos6.5 用户管理

    linux 用户管理 命令:useradd 选项: -c comment 备注信息 -d 用户目录 usr/test 不存在 则 -m test 创建 -s shell文件,指定用户的登录Shell. ...

  8. linux 学习7 用户管理相关文件 r

    7.1.用户配置文件 7.2.用户管理相关文件 7.3.用户管理命令 7.4.用户组管理命令 删除用户userdel [root@localhost ~]# userdel [-r] 用户名 //一定 ...

  9. Oracle【IT实验室】数据库备份与恢复之三:OS备份/用户管理的备份与恢复

    用户管理的备份与恢复也称 OS物理备份,是指通过数据库命令设置数据库为备份 状态,然后用操作系统命令,拷贝需要备份或恢复的文件.这种备份与恢复需要用户的 参与手工或自动完成. 对于使用 OS拷贝备份的 ...

随机推荐

  1. jingchi.ai 2017.11.25-26 Onsite面试

    时间:2017.11.25 - 11.26 地点:安徽安庆 来回路费报销,住宿报销. day1: 大哥哥问了我一个实际中他们遇到的问题.有n个点,将点进行分块输出,输出各个块的均值点.具体就是100* ...

  2. BZOJ 2194 快速傅立叶变换之二 | FFT

    BZOJ 2194 快速傅立叶变换之二 题意 给出两个长为\(n\)的数组\(a\)和\(b\),\(c_k = \sum_{i = k}^{n - 1} a[i] * b[i - k]\). 题解 ...

  3. 【NOI 2018】屠龙勇士(扩欧)

    题意理解错了... 一把剑打一条龙,打了$x$次后如果龙不死,你就Game Over了. 显然,面对每条龙使用的剑是固定的,如果所有龙中有一条没打死你就挂了. 可以知道,可行的答案集合就是所有龙的可行 ...

  4. [SDOI2009] HH去散步 (矩阵乘法)

    link $solution:$ 将边化为点后重新建矩阵,跑$T-1$幂即可(因为跑的是新边). 最后直接找与$x,y$所相连的边即可. #include<iostream> #inclu ...

  5. spring cloud-zuul的Filter详解(十一)

    本文转自:http://blog.csdn.net/liuchuanhong1/article/details/62236793 关于网关的作用,这里就不再次赘述了,我们今天的重点是zuul的Filt ...

  6. Head内常用标签

    一.标签分类 1.1 自闭和标签 自闭和标签只有开头没有结尾,自动闭合: <meta> 标签 <link> 标签 1.2主动闭合标签 有开头也有结尾,是主动闭合的,称为主动闭合 ...

  7. Linux运维二:CentOS6.6系统安装后的基本配置与优化

    CentOS6.6系统安装完成后还需要做一些配置与优化: 一:Linux内核版本号介绍 查看内核版本: [root@Gin scripts]# uname -r 2.6.32-504.el6.x86_ ...

  8. 关于connect by 误区讲解,纯属个人心得和经验,有图有文字

    本博客是自己在学习和工作途中的积累与总结,仅供自己参考,也欢迎大家转载,转载时请注明出处. http://www.cnblogs.com/king-xg/p/6927541.html 如果觉得对您有帮 ...

  9. 转:UIView之userInteractionEnabled属性介绍

    属性作用 该属性值为布尔类型,如属性本身的名称所释,该属性决定UIView是否接受并响应用户的交互. 当值设置为NO后,UIView会忽略那些原本应该发生在其自身的诸如touch和keyboard等用 ...

  10. bootstrap-tooltip+validate

    名称 返回类型 描述 validate(options) 返回:Validator 验证所选的FORM valid() 返回:Boolean 检查是否验证通过 rules() 返回:Options 返 ...