Telnet 首次登录Linux(密码正确登录不上)报错 Login incorrect

一、/etc/passwd与/etc/shadow

在Linux系统中的账户、密码被存放在两个文件中:/etc/passwd和/etc/shadow。

# cat /etc/passwd
root:x:0:0:root:/root:/bin/sh
daemon:x:1:1:daemon:/usr/sbin:/bin/false
bin:x:2:2:bin:/bin:/bin/false
sys:x:3:3:sys:/dev:/bin/false
sync:x:4:100:sync:/bin:/bin/sync
mail:x:8:8:mail:/var/spool/mail:/bin/false
www-data:x:33:33:www-data:/var/www:/bin/false
operator:x:37:37:Operator:/var:/bin/false
nobody:x:65534:65534:nobody:/home:/bin/false
sshd:x:1000:1000:SSH drop priv user:/var/empty:/bin/false

如上就是etc/passwd文件中的内容。可以观察到,其中每一行的内容从格式上来看都是一致的。即每一行都代表一个帐号,比如上图中的第一行root账号,第二行daemon账号,第三行bin账号等。这个文件中除了保存root账号,普通用户的账号之外,还保存了系统正常运行所需要的一些账号,比如daemon,bin,sys等系统账号。

Linux 系统中默认怎么会有这么多的用户?这些用户中的绝大多数是系统或服务正常运行所必需的用户,这种用户通常称为系统用户或伪用户。系统用户无法用来登录系统,但也不能删除,因为一旦删除,依赖这些用户运行的服务或程序就不能正常执行,会导致系统问题。

passwd一共由7个字段组成,6个冒号将其隔开。它们的含义分别为:

  • 1 用户名
  • 2 是否有加密口令,x表示有,不填表示无,采用MD5、DES加密。
  • 3 用户ID
  • 4 组ID
  • 5 注释字段
  • 6 登录目录
  • 7 所使用的shell程序
用户名:密码:UID(用户ID):GID(组ID):描述性信息:主目录:默认Shell

/etc/shadow 文件,用于存储 Linux 系统中用户的密码信息,又称为“影子文件”。前面介绍了 /etc/passwd 文件,由于该文件允许所有用户读取,易导致用户密码泄露,因此 Linux 系统将用户的密码信息从 /etc/passwd 文件中分离出来,并单独放到了此文件中。/etc/shadow 文件只有 root 用户拥有读权限,其他用户没有任何权限,这样就保证了用户密码的安全性。

# cat /etc/shadow
root:$5$xBnBrwleKnDI$DHkgvlnZO6fuk8535ZHJSbBaBapPgIRsyNjgC8rxyY0:::::::
daemon:*:::::::
bin:*:::::::
sys:*:::::::
sync:*:::::::
mail:*:::::::
www-data:*:::::::
operator:*:::::::
nobody:*:::::::
sshd:*:::::::
#

如上是/etc/shadow文件的内容,想要查看这个文件的内容,那么必须具备管理员权限才可以查看其内容。和passwd文件一样,冒号用来分隔每一项,每一行有9项。

用户名:加密密码:最后一次修改时间:最小修改时间间隔:密码有效期:密码需要变更前的警告天数:密码过期后的宽限时间:账号失效时间:保留字段
二、登录

以上两个文件是由系统编译生成的,当前以buildroot为例进行说明

img

如上,在执行make buildroot-menuconfig时设置好Root password之后,编译并烧录到板子上,在系统启动后我们能在/etc目录下看到如上两个文件,此时配置好网络之后,我们使用telnet 进行登录,发现输入正确的密码后一直不能连接报如下Login incorrect错误

sl:~$ telnet 10.19.15.103 61994
Trying 10.19.15.103...
Connected to 10.19.15.103.
Escape character is '^]'.

buildroot login: root
Password: 
Login incorrect

为了验证我们账户与密码的正确性,我们使用ssh再次进行连接,发现可以连接成功。于是我们尝试使用passwd命令修改密码,修改之后再使用telnet进行连接就可以,所以现象就很奇怪。

因此,我们对比了修改密码前后shadow文件中的root账户那行的信息发现,root那一行由最初的root:$5$xBnBrwleKnDI$DHkgvlnZO6fuk8535ZHJSbBaBapPgIRsyNjgC8rxyY0:::::::变为root:$5$n6FAir2UP2Ou8Q$umJebvqKr207YBCeYV5XH2pndsll.W5QeE9ZzKp3IHA:18332::::::,第一个冒号后是加密后的密码,这个没什么问题,主要是第二个冒号加了个最后一次修改时间,所以我们猜想是不是再修改密码之前的对应的这一项随机加个数字就可以了。

按照我们的猜想,果然随机加个数字,telnet初次连接就可以了,因此我们在编译配置buildroot时做了如下修改

编辑 buildroot/package/skeleton-init-common/skeleton-init-common.mk 文件

$ git diff buildroot/package/skeleton-init-common/skeleton-init-common.mk
diff --git a/buildroot/package/skeleton-init-common/skeleton-init-common.mk b/buildroot/package/skeleton-init-common/skeleton-init-common.mk
index 4a67f51..d78496b 100644
--- a/buildroot/package/skeleton-init-common/skeleton-init-common.mk
+++ b/buildroot/package/skeleton-init-common/skeleton-init-common.mk
@@ -76,7 +76,7 @@ else # !BR2_TARGET_ENABLE_ROOT_LOGIN
 SKELETON_INIT_COMMON_ROOT_PASSWORD = "*"
 endif
 define SKELETON_INIT_COMMON_SET_ROOT_PASSWD
-       $(SED) s,^root:[^:]*:,root:$(SKELETON_INIT_COMMON_ROOT_PASSWORD):, $(TARGET_DIR)/etc/shadow
+       $(SED) s,^root:[^:]*:,root:$(SKELETON_INIT_COMMON_ROOT_PASSWORD):1, $(TARGET_DIR)/etc/shadow
 endef
 SKELETON_INIT_COMMON_TARGET_FINALIZE_HOOKS += SKELETON_INIT_COMMON_SET_ROOT_PASSWD

如上修改之后重新编译buildroot后,系统起来telnet初次连接便成功了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当你在CentOS系统上输入密码时,出现"login incorrect"的提示,这通常意味着你输入的密码正确。首先,确保你输入的密码是准确的,特别注意大小写。你也可以尝试以下方法来解决该问题: 1. 重启系统:有时候,系统可能会出现一些临时问题,重启系统可以解决这些问题。 2. 检查键盘布局:如果你使用的是不同于默认键盘布局的语言或布局,请确保你输入密码时使用正确的键盘布局。 3. 检查用户名:确认你输入的用户名是否正确。有时候,我们可能会错误地输入了不正确的用户名。 4. 重置密码:如果你确信密码正确的,但仍然无法登录,你可以尝试重置密码。在CentOS系统中,可以使用root用户或者其他具有管理员权限的用户来重置密码。 - 如果你有root权限的用户,请使用root用户登录,并执行以下命令来重置密码: ``` passwd <用户名> ``` 其中,`<用户名>`是你要重置密码的用户名。 - 如果你没有root权限的用户,请联系具有管理员权限的用户,让其帮助你重置密码。 5. 检查文件系统:在某些情况下,文件系统的错误或损坏可能导致无法登录。你可以通过在恢复模式下运行文件系统检查命令来修复文件系统错误。 - 重启系统,并在引导菜单中选择恢复模式(通常是在引导菜单中选择"Advanced options",然后选择"Recovery mode")。 - 在恢复模式下,选择"fsck"或"check file system"选项来运行文件系统检查命令。 如果以上方法仍然不能解决问题,可能需要进一步检查系统日志以获取更多信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值