Linux创建多个用户,并赋予随机密码,不使用循环语句

简介:

Linux创建多个用户,并赋予随机密码,要求不使用循环语句。


方法一

使用基本命令useradd和passwd添加用户和添加密码。

(注:RANDOM随机生成数字(3-5个不等)。)


创建一个用户

[root@Server ~]# useradd stu01


创建多个用户就是要重复上面的命令多次,但是一个一个输入会比较麻烦,但是我们可以先生成一串序列,然后使用替换的方法将序列替换成上面的格式。

[root@Server ~]# seq 10

1

2

3

4

5

6

7

8

9

10

[root@Server ~]# 


然后我们使用sed命令将上面的序列替换成我们需要的命令

[root@Server ~]# seq -w 10|sed -r 's#(.*)#useradd stu\1#g'

useradd stu01

useradd stu02

useradd stu03

useradd stu04

useradd stu05

useradd stu06

useradd stu07

useradd stu08

useradd stu09

useradd stu10

[root@Server ~]# 


这样我们就可以一次性创建多个用户了,只需要将上面的内容利用管道传输给bash就能执行命令了。

[root@Server ~]# seq -w 10|sed -r "s#(.*)#useradd stu\1#g"|bash

[root@Server ~]# tail -10 /etc/passwd

stu01:x:503:503::/home/stu01:/bin/bash

stu02:x:504:504::/home/stu02:/bin/bash

stu03:x:505:505::/home/stu03:/bin/bash

stu04:x:506:506::/home/stu04:/bin/bash

stu05:x:507:507::/home/stu05:/bin/bash

stu06:x:508:508::/home/stu06:/bin/bash

stu07:x:509:509::/home/stu07:/bin/bash

stu08:x:510:510::/home/stu08:/bin/bash

stu09:x:511:511::/home/stu09:/bin/bash

stu10:x:512:512::/home/stu10:/bin/bash

[root@Server ~]#


为这10个用户添加随机密码

基本思想和上面一样,先创建序列然后替换成我们需要的命令。

[root@Server ~]# seq -w 10|sed -r 's#(.*)#passwd stu\1#g'

passwd stu01

passwd stu02

passwd stu03

passwd stu04

passwd stu05

passwd stu06

passwd stu07

passwd stu08

passwd stu09

passwd stu10

[root@Server ~]# 


到这里后就要一个一个输入密码比较麻烦,但是passwd有一个参数--stdin可以直接使用echo命令将密码传入进去,题目要求是创建随机密码,这里要用到一个随机变量参数RANDOM

[root@Server ~]# echo $((RANDOM))

2492

[root@Server ~]# echo $((RANDOM))

15380

[root@Server ~]# echo $((RANDOM))

20658

[root@Server ~]# echo $((RANDOM))

24952

[root@Server ~]# 

它会生成3到5个随机数,我们可以将这些数通过管道传输给passwd然后进行密码修改。

但是修改后的密码又看不到,设置了等于没有设置,于是我们再使用追加重定向将密码再传进一个文件夹中,这样就可以既添加了随机密码又可以看到密码是多少。

[root@Server ~]# seq -w 10|sed -r 's#(.*)#jack="$((RANDOM))" ;echo $jack|passwd --stdin stu\1;echo "stu\1:$jack">>/mima.log#g'|bash

Changing password for user stu01.

passwd: all authentication tokens updated successfully.

Changing password for user stu02.

passwd: all authentication tokens updated successfully.

Changing password for user stu03.

passwd: all authentication tokens updated successfully.

Changing password for user stu04.

passwd: all authentication tokens updated successfully.

Changing password for user stu05.

passwd: all authentication tokens updated successfully.

Changing password for user stu06.

passwd: all authentication tokens updated successfully.

Changing password for user stu07.

passwd: all authentication tokens updated successfully.

Changing password for user stu08.

passwd: all authentication tokens updated successfully.

Changing password for user stu09.

passwd: all authentication tokens updated successfully.

Changing password for user stu10.

passwd: all authentication tokens updated successfully.

[root@Server ~]# tail -10 /mima.log 

stu01:20103

stu02:5338

stu03:12149

stu04:15405

stu05:13777

stu06:27532

stu07:28049

stu08:2620

stu09:17935

stu10:22851

[root@Server ~]# 



方法二

使用chpasswd更改用户密码

chpasswd是一个批量更改用户密码的命令,它是先读取一个文件,然后根据文件的内容,然后更改密码,文件内容格式如下:

USERNAME:PASS WORD

冒号左边是用户名,右边是要修改的密码。


首先创建10个用户

[root@Server ~]# seq -w 10|sed -r 's#(.*)#userdel -r stu\1#g'|bash

[root@Server ~]# seq -w 10|sed -r "s#(.*)#useradd stu\1#g"|bash

[root@Server ~]# tail -10 /etc/passwd

stu01:x:502:502::/home/stu01:/bin/bash

stu02:x:503:503::/home/stu02:/bin/bash

stu03:x:504:504::/home/stu03:/bin/bash

stu04:x:505:505::/home/stu04:/bin/bash

stu05:x:506:506::/home/stu05:/bin/bash

stu06:x:507:507::/home/stu06:/bin/bash

stu07:x:508:508::/home/stu07:/bin/bash

stu08:x:509:509::/home/stu08:/bin/bash

stu09:x:510:510::/home/stu09:/bin/bash

stu10:x:511:511::/home/stu10:/bin/bash

[root@Server ~]# 

然后在文件中写入要修改的用户名和密码

[root@Server ~]# echo stu{01..10}:$((RANDOM))|tr " " "\n" >mima.log

[root@Server ~]# cat mima.log 

stu01:7119

stu02:27272

stu03:16673

stu04:24743

stu05:10044

stu06:4649

stu07:19767

stu08:29380

stu09:21922

stu10:13488

[root@Server ~]# 

上面的tr命令作用是将前面的空格,更改成换行符,这样就不会在一行显示,因为chpasswd对文件内容格式有要求。


然后我们执行chpasswd命令,并测试是否能进入。

root@Server ~]# chpasswd < mima.log 

[root@Server ~]# su - stu01

[stu01@Server ~]$ su - stu02

Password: 

[stu02@Server ~]$ whoami 

stu02

[stu02@Server ~]$ 



本文转自 dengaosky 51CTO博客,原文链接:http://blog.51cto.com/dengaosky/1854534,如需转载请自行联系原作者

相关文章
|
2月前
|
安全 Linux 数据安全/隐私保护
Linux 忘记密码解决方法
Linux 忘记密码解决方法
51 2
Linux 忘记密码解决方法
|
2月前
|
Linux Shell 数据安全/隐私保护
Linux如何在服务器上进行密码的修改?
【10月更文挑战第6天】Linux如何在服务器上进行密码的修改?
158 1
|
2月前
|
Linux 数据安全/隐私保护 索引
linux inode索引节点使用率100% 解决+hustoj忘记密码+最新MDK注册方法
linux inode索引节点使用率100% 解决+hustoj忘记密码+最新MDK注册方法
45 1
|
2月前
|
Ubuntu Linux Shell
Linux系统密码忘记
【10月更文挑战第2天】在Linux系统中,若忘记密码,可以通过单用户模式或使用Live CD/USB来重置。对于Ubuntu系统,可通过GRUB引导菜单进入单用户模式,利用命令行重置密码;或使用Live CD/USB启动并挂载硬盘分区后修改密码文件。CentOS系统同样支持单用户模式重置密码,也可借助安装介质进入救援模式,挂载文件系统后进行密码重置。这些方法均能在忘记密码的情况下帮助恢复系统访问。
|
3月前
|
安全 Linux 数据安全/隐私保护
Linux强制修改用户密码
【9月更文挑战第21天】在 Linux 系统中,可使用以下方法强制修改用户密码:1. 使用 `passwd` 命令,以 root 身份运行 `passwd username` 修改密码,加 `-f` 选项可跳过复杂度检查;2. 使用 `chpasswd` 命令,通过文本文件批量设置密码;3. 结合 `usermod -e 0 username` 和 `chpasswd` 强制用户下次登录时更改密码。注意操作时需确保安全性与合理性。
329 4
|
4月前
|
Linux Shell 数据安全/隐私保护
Linux用户账户管理精髓:创建、删除、密码与会话管理全攻略
本文档介绍了Linux系统中用户账户管理的关键操作,包括创建与删除用户、设置及修改密码、用户切换与会话管理等内容。通过理论说明与具体命令示例,如使用`useradd`、`userdel`、`passwd`和`su`等命令,帮助系统管理员更好地掌握这些基本技能,从而有效提升系统的安全性和管理效率。此外,还介绍了如何利用`screen`等工具进行会话管理,确保即便在网络中断的情况下也能维持会话的持续运行。
113 3
|
4月前
|
安全 关系型数据库 MySQL
在Linux中,如何重置 mysql root 密码?
在Linux中,如何重置 mysql root 密码?
|
5月前
|
关系型数据库 MySQL Linux
|
5月前
|
弹性计算 Linux 数据安全/隐私保护
云服务器 ECS产品使用问题之linux如何设置服务器密码
云服务器ECS(Elastic Compute Service)是各大云服务商阿里云提供的一种基础云计算服务,它允许用户租用云端计算资源来部署和运行各种应用程序。以下是一个关于如何使用ECS产品的综合指南。
|
6月前
|
Ubuntu 安全 Linux
Linux必备|如何重置忘记的 Root 密码
Linux必备|如何重置忘记的 Root 密码
921 7