赞
踩
/etc/motd
是ssh登录前欢迎语文件.
# 配置登录后的欢迎语
# 重定向欢迎语写入到/etc/motd
echo 'hello word !' >> /etc/motd
/etc/issue
是ssh登录后欢迎语文件.
# 配置登录前的欢迎语
# 重定向欢迎语写入到/etc/issue
echo 'hello word !' >> /etc/issue
LInux的用户密码
存放在/etc/shadows
文件中
配置文件信息 | 文件名称 |
---|---|
用户信息文件 | /etc/passwd |
密码文件 | /etc/shadow |
用户组文件 | /etc/group |
用户组密码文件 | /etc/gshadow |
用户配置文件 | /etc/login.defs , /etc/default/useradd |
新用户信息文件 | /etc/skel |
登录信息 | /etc/motd |
/etc/passwd
用户账号信息文件/etc/passwd
:用户账号信息文件。
/etc/shadows
用户密码文件/etc/shadow
:用户账号信息加密文件(又称为“影子文件”)
/etc/passwd
文件允许所有用户读取,容易导致密码泄露,因此将密码信息从该文件中分离出来, 单独放置在/etc/shadow
文件中。/etc/shadow
文件只有超级用户(root用户)
具有读
权限,其他用户均没有权限,从而保证了用户密码的安全性。
密码
在经由/etc/shadow
保护后,在/etc/passwd
文件的用户记录中只会以“X
”的形式呈现。
与/etc/passwd
文件相似,每一行记录代表一个用户,且以“:”隔开,不同之处在于/etc/passwd
中每行记录被分为九
个字段。
https://www.linuxcool.com/passwd
https://wangchujiang.com/linux-command/c/passwd.html
passwd
命令用于更新/etc/shadow
文件中用户的身份验证令牌。
(root
用户可以修改任何用户的密码,普通用户
只能修改自身
的密码)
-n | 设置修改密码最短天数 |
---|---|
-L | 锁定用户密码,使密码无效 |
-l | 锁定用户的密码值,不允许修改 |
-u | 解开已上锁的密码 |
-x | 设置修改密码最长天数 |
-w | 设置用户在密码过期前多少天收到警告信息 -i 设置密码过期多少天后禁用账户 |
-d | 删除用户密码 |
-f | 强制执行 |
-k | 设置只有在密码过期失效后,方能更新 |
-s | 列出密码的相关信息(仅有系统管理员才能使用) |
-S | 显示用户密码信息 |
# 当前用户修改密码,直接使用passwd
passwd
# 为其他用户修改密码
passwd 用户名
# 查看用户的密码年龄
chage -l 用户名
禁用用户
passwd
命令用于更新/etc/shadow
文件中用户的身份验证令牌。
https://zhuanlan.zhihu.com/p/71834401
# 锁定用户的密码
## -l 锁定用户的密码值,不允许修改
passwd -l daygeek
## 回显
Locking password for user daygeek.
passwd: Success
# 查看用户的密码锁定状态
## -S 显示用户密码信息
passwd -S daygeek
# 解锁用户的密码
## -u 解开已上锁的密码
passwd -u daygeek
# 查看账号的密码状态
## -S 显示用户密码信息
passwd -S root
帐户密码状态的简短信息。
LK
:密码被锁定NP
:没有设置密码PS
:密码已设置单引号' '
,双引号" "
的区别
:
' '
剥夺了所有字符的特殊含义,单引号' '
内就变成了单纯的字符。" "
则对于双引号" "
内的参数替换($)
和命令替换(``)
是个例外。# 用echo写入新密码到passwd中
## passwd --stdin:从标准输入(比如管道)写入密码
# echo双引号不要使用特殊字符,比如!,会被转义
## echo使用单引号,引号内的字符不会被转义
echo '新密码'|passwd --stdin 用户名
# Ubuntu不支持 --stdin参数,可以使用替代命令
echo user:pass | chpasswd
## -d 删除已有密码
passwd -d 用户名
[root@localhost ~]# chage --help
用法:chage [选项] 登录
选项:
-d, --lastday 最近日期 将最近一次密码设置时间设为“最近日期”
-E, --expiredate 过期日期 将帐户过期时间设为“过期日期”
-h, --help 显示此帮助信息并推出
-I, --inactive INACITVE 过期 INACTIVE 天数后,设定密码为失效状态
-l, --list 显示帐户年龄信息
-m, --mindays 最小天数 将两次改变密码之间相距的最小天数设为“最小天数”
-M, --maxdays 最大天数 将两次改变密码之间相距的最大天数设为“最大天数”
-R, --root CHROOT_DIR chroot 到的目录
-W, --warndays 警告天数 将过期警告天数设为“警告天数”
# 查看上次密码的修改时间
# 查看密码过期配置
chage -l root
# 修改testt用户密码信息,设置最大有效期为120天,最小有效期为7天
## -M, --maxdays 最大天数 将两次改变密码之间相距的最大天数设为“最大天数”
## -m, --mindays 最小天数 将两次改变密码之间相距的最小天数设为“最小天数”
chage -M 120 -m 7 test
# test这个账号的有效期是2014-09-30
## -E, --expiredate 过期日期 将帐户过期时间设为“过期日期”
chage -E '2014-09-30' test
# 修改用户的密码有效期为永久(5个9)
## -M, --maxdays 最大天数 将两次改变密码之间相距的最大天数设为“最大天数”
chage -M 99999 用户名
# 使密码立即失效
# 强制要求用户登陆时修改密码
## -d, --lastday 最近日期 将最近一次密码设置时间设为“最近日期”
chage -d 0 用户名
# 查看密码过期时间
[root@localhost ~]# chage -l use1
最近一次密码修改时间 :密码必须修改
密码过期时间 :密码必须修改
密码失效时间 :密码必须修改
帐户过期时间 :从不
两次改变密码之间相距的最小天数 :0
两次改变密码之间相距的最大天数 :99999
在密码过期之前警告的天数 :7
[student@workstation data-secret]$ openssl passwd --help Usage: passwd [options] Valid options are: -help Display this summary -in infile Read passwords from file -noverify Never verify when reading password from terminal -quiet No warnings -table Format output as table -reverse Switch table columns -salt val Use provided salt -stdin Read passwords from stdin -6 SHA512-based password algorithm -5 SHA256-based password algorithm -apr1 MD5-based password algorithm, Apache variant -1 MD5-based password algorithm -aixmd5 AIX MD5-based password algorithm -crypt Standard Unix password algorithm (default) -rand val Load the file(s) into the random number generator -writerand outfile Write random data to the specified file
[student@workstation data-secret]$ openssl passwd -6
Password: # 提示输入密码
Verifying - Password: # 确认密码
# 生成的加密后的密码
$6$hkf.tpoz/woyZn1c$ArDSHie9USt44nnqymqL6OZWKsI3e0WWl4NedhfmQOlSEN6er18SYSfyGnvxQmEgC81DLKuERhqDm5Ei3iIDw0
使用-salt 字符串 给密码加盐
不同的盐,密码相同,算法相同,密文不同
相同的盐,密码相同,算法相同,密文相同
# 加盐rhel生成密码密文
[student@workstation data-secret]$ openssl passwd -6 -salt rhel
Password: # 输入密码
## 生成的密文
$6$rhel$2JncQy/NAQr4GHoVgz49YGRni8lXx3jakLxYxEBcTYLN8hh7Nu9fJc4zSbRhiJmv0vBlB6W3YyQp.nLZo8MCy0
# 再次实验加盐rhel生成密文
[student@workstation data-secret]$ openssl passwd -6 -salt rhel
Password: # 输入密码
## 生成的密文与上次密文完全一致
$6$rhel$2JncQy/NAQr4GHoVgz49YGRni8lXx3jakLxYxEBcTYLN8hh7Nu9fJc4zSbRhiJmv0vBlB6W3YyQp.nLZo8MCy0
$6$rhel$2JncQy/NAQr4GHoVgz49YGRni8lXx3jakLxYxEBcTYLN8hh7Nu9fJc4zSbRhiJmv0vBlB6W3YyQp.nLZo8MCy0
## $6 表示加密算法sha512
## $rhel 表示盐时rhel
## 第三个$之后才是 算法+盐+原密码 生成的密文
vim /etc/login.defs
## 修改默认密码策略为20天后过期
PASS_MAX_DAYS 20
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。