需完成如下设置:

1、密码必须符合复杂度要求,字母、数字、特殊字符组成。长度大于8位。
2、密码定期更改,最长不超过90天。
3、用户不能重复使用5次内已使用的口令。

4、尝试登陆失败错误次数,必须设置不能超过5次,超过5次后,暂时锁定20分钟或以上。 


安装 PAM 的 cracklib 模块,cracklib 能提供额外的密码检查能力

1、密码必须符合复杂度要求,字母、数字、特殊字符组成。长度大于8位。

修改文件:/ect/pam.d/system-auth,找到同时有 “password” 和 “pam_cracklib.so” 字段

password    requisite     pam_cracklib.so retry=3 difok=3 minlen=8 lcredit=-1 dcredit=-1 ocredit=-1

2、密码定期更改,最长不超过90天。

配置文件中 /etc/login.defs 修改配置文件:

PASS_MAX_DAYS   90 

PASS_MIN_DAYS   0 

PASS_MIN_LEN    5 

PASS_WARN_AGE   7

通过chage -l xxx(用户名)  查看定期修改的时间

3、用户不能重复使用5次内已使用的口令。

修改文件:/ect/pam.d/system-auth,找到同时有 “password” 和 “pam_unix.so” 字段

password    sufficient    pam_unix.so sha512 shadow nullok try_first_pass use_authtok remember=5

通过/etc/security/opasswd中查看禁止使用近期用过的5个密码


4、尝试登陆失败错误次数,必须设置不能超过5次,超过5次后,暂时锁定20分钟或以上。 

查看系统中是否含有pam_tally2.so模块,如果没有,则需要使用pam_tally.so模块

find /lib* -iname "pam_tally2.so"  

find /lib* -iname "pam_tally.so"

在配置文件中/etc/pam.d/sshd中的第二行,如下添加内容

auth       required     pam_tally2.so deny=5 unlock_time=1200

查看用户错误登陆次数:

pam_tally2 --user xxx (用户名)


pam_cracklib.so比较重要和难于理解的是它的一些参数和计数方法,其常用参数包括:   

debug:将调试信息写入日志;

type=xxx:当添加/修改密码时,系统给出的缺省提示符是“New UNIX password:”以及“Retype UNIX

password:”,而使用该参数可以自定义输入密码的提示符,比如指定type=your own word;

retry=N:定义登录/修改密码失败时,可以重试的次数;

Difok=N:定义新密码中必须有几个字符要与旧密码不同。但是如果新密码中有1/2以上的字符与旧密码不同时,该新密码将被接受;

minlen=N:定义用户密码的最小长度;

dcredit=N:定义用户密码中必须包含多少个数字;

ucredit=N:定义用户密码中必须包含多少个大写字母;

lcredit=N:定义用户密码中必须包含多少个小些字母;

ocredit=N:定义用户密码中必须包含多少个特殊字符(除数字、字母之外);