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拷贝备份的 ...
随机推荐
- [UVA 10635] Prince ans Princess
图片加载可能有点慢,请跳过题面先看题解,谢谢 这道题... 还是要点思维的... 第一眼看是个最长公共子序列,但是, \(N\le 62500\) ,并不能 \(O(n^2)\) 求 $ $ 这道题有 ...
- IDEA的强大
由于朋友推荐,转战IDEA数日,发现一个字就是,牛,完爆任何开发工具,让你代码上瘾的工具. 它集合了所有的开发所需要的东西,且智能化方便,适合开发有一定经验的人去使用,你会爱上它. 下面是快捷键的使用 ...
- Html5 drag&drop
下面是一个拖放例子 定义如下的两个div,分别是用于拖放后放置新元素的容器和可拖动的元素: <body> <div id="holder" style=" ...
- Lnmp上安装Yaf学习(一)
今天学习Lnmp上面如何安装Yaf流程 一.安装Lnmp 集成环境 访问路径:https://lnmp.org/install.html 这里我安装稳定版lnmp 1) wget -c http: ...
- java反射获取class
- ACF/PACF,残差白噪声的检验问题
关于自相关.偏自相关: 一.自协方差和自相关系数 p阶自回归AR(p) 自协方差 r(t,s)=E[X(t)-EX(t)][X(s)-EX(s)] 自相关系数ACF ...
- 最短路径算法的实现(dijskstra):Python
dijskstra最短路径算法步骤: 输入:图G=(V(G),E(G))有一个源顶点S和一个汇顶点t,以及对所有的边ij属于E(G)的非负边长出cij. 输出:G从s到t的最短路径的长度. 第0步:从 ...
- vue 项目代码初始化
1. <meta>补充 <head> <meta charset="utf-8"> <meta name="viewport&q ...
- 如何在Mongodb中实现数据超时自动删除功能?
在工作过程中,我们难免会遇到这样的问题,我们想保存一些数据,但是我们对这些数据的要求并不高,有时候往往只是想要某个时间范围内的数据,比如我们如果永远只关心从当前时间往前推半年内的数据特性,那么我们就不 ...
- js 正则表达式 整数或小数
非零开头的整数或小数 /^[1-9][0-9]*([.][0-9]+)?$/ 非零开头的整数或两位小数 /^[1-9][0-9]*([.][0-9]{1,2})?$/ /^[1-9][0-9]*([. ...