Linux复杂密码策略设置教程
时间:2025-10-01 11:51:50 409浏览 收藏
在文章实战开发的过程中,我们经常会遇到一些这样那样的问题,然后要卡好半天,等问题解决了才发现原来一些细节知识点还是没有掌握好。今天golang学习网就整理分享《Linux设置复杂密码策略教程》,聊聊,希望可以帮助到正在努力赚钱的你。
配置Linux密码策略需先安装libpam-pwquality模块,再编辑/etc/security/pwquality.conf设置最小长度12位及字符类型要求,启用reject_username防止用户名作密码,随后在/etc/pam.d/common-password中添加requisite控制并设retry=3,接着修改/etc/login.defs设定PASS_MAX_DAYS为90、PASS_MIN_DAYS为5,并在common-password中添加remember=5以防止重用最近5个密码,最后通过su切换用户执行passwd测试策略,验证弱密码被拒而强密码可通过。

如果您希望提升Linux系统的安全性,防止弱密码带来的潜在风险,可以通过配置用户密码策略来强制用户使用符合安全要求的密码。以下是实现复杂密码策略的具体步骤。
本文运行环境:Dell XPS 13,Ubuntu 24.04
一、安装PAM密码强度检查模块
PAM(Pluggable Authentication Modules)是Linux系统中用于管理认证方式的核心组件,通过其pam_pwquality模块可实现密码复杂度控制。需要先确保该模块已安装。
1、打开终端,执行命令 sudo apt install libpam-pwquality 安装密码质量检测库。
2、确认软件包安装成功,检查 /etc/pam.d/common-password 文件中是否包含对 pam_pwquality.so 的引用。
二、配置pam_pwquality.conf参数
/etc/security/pwquality.conf 文件用于定义密码强度规则,包括长度、字符种类、连续字符限制等。修改此文件可自定义策略要求。
1、使用文本编辑器打开配置文件:sudo nano /etc/security/pwquality.conf。
2、设置最小长度:修改 minlen = 12 以要求密码至少12位。
3、启用字符类别检查:设置 dcredit = -1(至少一位数字),ucredit = -1(大写字母),lcredit = -1(小写字母),ocredit = -1(特殊符号)。
4、禁止使用用户名或逆序:启用 reject_username = 1 防止用户使用自身用户名作为密码。
三、在PAM认证流程中启用策略
需将密码强度模块集成到系统认证流程中,确保所有涉及密码更改的操作都受控于新规则。
1、编辑PAM密码认证配置文件:sudo nano /etc/pam.d/common-password。
2、找到包含 pam_pwquality.so 的行,若不存在则添加:password requisite pam_pwquality.so retry=3。
3、设置重试次数为3次,允许用户在输入不符合规则的密码后有三次修正机会。
四、设置密码有效期与历史记录
通过限制密码使用周期和防止重复使用旧密码,进一步增强账户安全性。
1、编辑登录定义文件:sudo nano /etc/login.defs。
2、修改 PASS_MAX_DAYS 90 表示密码最长使用90天。
3、设置 PASS_MIN_DAYS 5 防止用户在5天内频繁更改密码。
4、配置密码历史:在 /etc/pam.d/common-password 中添加 remember=5 参数,实现最近5个密码不可重复使用。
五、测试密码策略生效情况
通过实际修改用户密码验证策略是否按预期工作,确保规则正确拦截弱密码并接受合规密码。
1、切换到普通用户环境:su - username。
2、执行 passwd 命令尝试修改密码。
3、输入一个不符合规则的密码(如全小写无数字),观察系统是否拒绝并提示错误原因。
4、再输入一个满足长度和字符类型要求的密码,确认修改成功。
今天关于《Linux复杂密码策略设置教程》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于Linux,密码策略,pam,pwquality.conf,common-password的内容请关注golang学习网公众号!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
388 收藏
-
245 收藏
-
406 收藏
-
412 收藏
-
242 收藏
-
466 收藏
-
456 收藏
-
226 收藏
-
116 收藏
-
175 收藏
-
127 收藏
-
218 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习