shell用户管理->
用户的添加与删除练习
-> 脚本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用户管理->的更多相关文章
- 【shell 练习4】编写Shell用户管理脚本(二)
		一.创建.删除.查看用户,随机生成八位数密码 #!/bin/bash #Author:yanglt #!/bin/bash #Author:yanglt #Blog:https://www.cnblo ... 
- linux 用户管理
		linux 用户管理 创建一个用户 foo 这个用户只能在/home/foo 上面增加删除文件, foo 不能在其他目录加减文件 useradd -d /home/foo -m foo [root@] ... 
- mongodb的用户管理及安全认证
		1.确认mongodb的版本 > use admin switched to db admin > db.runCommand({}) { "version" : &q ... 
- linux 用户管理(一)
		本节内容梗概: 1.用户管理配置文件 2.用户管理命令 3.用户组管理命令 4.批量添加用户 5.用户授权 学东西先讲原理,所以从配置文件入手 1.用户信息文件 /etc/passwd 存放了用户的 ... 
- 第3章 Linux常用命令(4)_帮助、用户管理和解压缩命令
		4. 帮助命令 4.1 获取帮助信息:man (1)man命令 命令名称 man(英语原义:manual) 命令所在路径 usr/bin/man 执行权限 所有用户 语法 man [级别] [命令或配 ... 
- Linux用户管理.md
		用户与组的概念 linux多用户,多任务的特性 Linux是一个真实的.完整的多用户多任务操作系统,多用户多任务就是可以在系统上建立多个用户,而多个用户可以在同一时间内登录同一个系统执行各自不同的任务 ... 
- centos6.5 用户管理
		linux 用户管理 命令:useradd 选项: -c comment 备注信息 -d 用户目录 usr/test 不存在 则 -m test 创建 -s shell文件,指定用户的登录Shell. ... 
- linux 学习7 用户管理相关文件 r
		7.1.用户配置文件 7.2.用户管理相关文件 7.3.用户管理命令 7.4.用户组管理命令 删除用户userdel [root@localhost ~]# userdel [-r] 用户名 //一定 ... 
- Oracle【IT实验室】数据库备份与恢复之三:OS备份/用户管理的备份与恢复
		用户管理的备份与恢复也称 OS物理备份,是指通过数据库命令设置数据库为备份 状态,然后用操作系统命令,拷贝需要备份或恢复的文件.这种备份与恢复需要用户的 参与手工或自动完成. 对于使用 OS拷贝备份的 ... 
随机推荐
- linq 获取实体列表中的某个字段返回ilist<string>
			var list = list.Select(t => t.Field<string>("列名")).ToList(); var list = list.Se ... 
- CF17E Palisection——优秀的综合计数题
			题意翻译 给定一个长度为n的小写字母串.问你有多少对相交的回文子 串(包含也算相交) . 输入格式 第一行是字符串长度n(1<=n<=2*10^6),第二行字符串 输出格式 相交的回文子串 ... 
- UVALive 7505 Hungry Game of Ants (2015Ecfinal)
			题意: 长度是n的线段上点的编号从1~n,每个点有一只蚂蚁蚂蚁的体重等于该点的编号,最初每只蚂蚁可以选择向右走或者向左走两只蚂蚁相遇时体重大的吃掉体重小的并且体重增加为两只的体重和,走到边界时掉头,问 ... 
- 利用ansible来做tomcat应用的持续交付
			https://www.jianshu.com/p/fca8f91ae223 在做持续交付这件事,想必大家都是用jenkins这款程序来做基石.当然,我们这次也是用jenkins作为承载工具,jenk ... 
- Django templates and models
			models templates models and databases models 如何理解models A model is the single, definitive source of ... 
- python 中的 %s,%r,__str__,__repr__
			1.%s,%r的区别 在进行格式化输出时,%r 与 %s 的区别就好比 repr() 函数处理对象与 str() 函数处理对象的差别. %s ⇒ str(),比较智能: %r ⇒ repr(),处理较 ... 
- linux  diff 命令
			diff 命令是 linux上非常重要的工具,用于比较文件的内容,特别是比较两个版本不同的文件以找到改动的地方.diff在命令行中打印每一个行的改动.最新版本的diff还支持二进制文件.diff程序的 ... 
- git 提交模板配置
			1.创建模板文件,比如gitTemplate.txt,内容如下: ABSTRACT:修改自测发现的多度数据同步相关问题. Bug Fix [Y/N]:NBug ID:New Feature [Y/N] ... 
- bzoj千题计划133:bzoj3130: [Sdoi2013]费用流
			http://www.lydsy.com/JudgeOnline/problem.php?id=3130 第一问就是个最大流 第二问: Bob希望总费用尽量大,那肯定是把所有的花费加到流量最大的那一条 ... 
- centos无法通过ssh连接的解决
			系统环境是centos7,虚拟机环境下的.在使用ssh工具连接虚拟机的时候发现连接不上,用的是root 先检查openssh-server是否安装: yum list installed | grep ... 
