如何秒速登录SSH/串口终端?

标准方法:使用 passwd 命令

适用场景:系统已安装 passwd 工具(BusyBox或完整Linux环境)。

passwd root
# 3. 按提示输入两次新密码
Enter new password: ******
Retype new password: ******

关键提示

  • 普通用户仅能修改自身密码,root用户可修改任意账户密码(如 passwd username)。
  • 密码需满足强度规则(长度、字符组合),否则可能报错 BAD PASSWORD

手动编辑密码文件(无passwd工具时)

适用场景passwd命令不可用或需脚本批量操作。

步骤

  1. 生成加密密码
    在PC端使用 opensslmkpasswd 生成SHA-512加密字符串(嵌入式设备可能无此工具):

    openssl passwd -6 -salt $(openssl rand -base64 6) your_password
    # 输出示例:$6$salt$encrypted_string
  2. 修改 /etc/shadow 文件

    • 挂载文件系统为可写(若只读):
      mount -o remount,rw /
    • 编辑 /etc/shadow,找到目标行(如 root:旧密码字段:...),替换加密字符串:
      vi /etc/shadow
      # 将root行第二个字段改为生成的加密串
      root:$6$salt$encrypted_string:19450:0:99999:7:::
  3. 恢复只读挂载(如适用):

    mount -o remount,ro /

特殊场景处理

  1. 只读文件系统

    • 临时挂载可写:mount -o remount,rw /
    • 修改后还原:mount -o remount,ro /
    • 若需永久修改,需调整启动脚本中的挂载参数。
  2. BusyBox环境简化操作
    BusyBox的 passwd 可能无交互提示,直接指定密码:

    echo -e "new_password\nnew_password" | passwd root
  3. 恢复出厂默认密码
    查找系统重置脚本(通常为 /bin/factory-reset)或重新烧录包含默认配置的固件。


安全与验证

  1. 密码强度要求

    • 长度≥8字符,混合大小写、数字及符号。
    • 避免常见词汇(如 admin/123456)。
  2. 修改后验证

    su - username  # 切换用户测试新密码
  3. 文件权限检查
    确保 /etc/shadow 权限为 640,属主 root:root

    chmod 640 /etc/shadow
    chown root:root /etc/shadow

故障排除

  • 报错:passwd: Authentication token manipulation error
    原因:文件系统只读或磁盘满。
    解决:mount -o remount,rw / 并检查空间(df -h)。

  • 报错:passwd: System error
    原因:/etc/shadow 权限异常。
    解决:恢复权限 chmod 640 /etc/shadow

  • 密码未生效
    原因:加密算法不匹配(如MD5 vs SHA-512)。
    解决:确认生成密码时指定算法(-6 为SHA-512)。


嵌入式Linux修改密码的核心是:

  1. 优先使用 passwd 命令(安全可靠)。
  2. 手动编辑 /etc/shadow 仅作为备用方案,需严格注意加密算法和权限。
  3. 在只读文件系统中,需先解除挂载保护。

引用说明:本文方法参考Linux标准文档(man 5 shadow)、BusyBox官方手册及嵌入式系统安全实践,操作涉及系统关键文件,建议在测试环境验证后实施。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/9848.html

(0)
酷番叔酷番叔
上一篇 2025年8月7日 09:08
下一篇 2025年8月7日 09:33

相关推荐

  • linux中如何安装flash

    Linux中安装Flash,可通过Adobe官网下载适用于Linux的Flash Player安装包

    2025年8月14日
    11500
  • 如何快速解决常见问题

    在Linux系统中运行a.out文件是C/C++程序开发的常见操作,a.out是Unix/Linux传统的可执行文件默认名称(源于”assembler output”),现在虽然GCC默认生成的文件名已变为与源代码相关,但了解如何运行它仍具有实用价值,以下为详细步骤及注意事项:a.out是什么?a.out是GC……

    2025年7月19日
    14300
  • Linux系统如何删除文件?操作方法与步骤详解

    在Linux系统中,删除文件是日常操作中常见的任务,但不同场景下需要使用不同的命令和方法,掌握正确的删除方式不仅能提高效率,还能避免误操作导致的数据丢失,本文将详细介绍Linux中删除文件的各类方法、注意事项及实用技巧,基础删除命令:rmrm(remove)是Linux中最常用的删除文件命令,支持删除单个文件……

    2025年8月28日
    1.6K00
  • 如何删除名为 mylink 的软链接?

    删除软链接的核心命令使用 rm 命令(最常用)rm /path/to/softlink_name参数说明:rm:删除文件或链接的标准命令,/path/to/softlink_name:软链接的完整路径(结尾不能加 ),示例:使用 unlink 命令(专用于单文件删除)unlink /path/to/softli……

    2025年7月29日
    10400
  • Linux系统如何导入文件?

    在Linux系统中,“导入文件”是一个涵盖多种场景的操作,可能涉及从本地系统复制、从网络传输、从外部设备读取,或针对特定应用(如数据库、配置管理)的文件导入,本文将详细讲解不同场景下的文件导入方法,包括命令行工具、图形界面操作及特殊场景处理,帮助用户高效完成文件导入任务,本地文件导入:复制与移动本地文件导入主要……

    2025年9月16日
    9000

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信