Linux中为SSH启用双因素身份验证

Linux中为SSH启用双因素身份验证无论您是将 FedoraLinux 用于桌面还是服务器 都应考虑为 SecureShell SSH 登录启用双因素身份验证 为什么 因为 SSH 是远程登录服务器的主要方式 所以您最不希望的是将该服务保持打开状态以进行攻击 更好地锁定它的一种方法是为 SSH 启用双因素身份验证 我想引导您完成这样做的步骤 这样您就可以享受 Fedora 台式机和服务器的更高安全性 准备 Fedora

无论您是将Fedora Linux用于桌面还是服务器,都应考虑为Secure Shell(SSH)登录启用双因素身份验证。为什么?因为SSH是远程登录服务器的主要方式,所以您最不希望的是将该服务保持打开状态以进行攻击。

更好地锁定它的一种方法是为SSH启用双因素身份验证。我想引导您完成这样做的步骤,这样您就可以享受Fedora台式机和服务器的更高安全性。

准备:Fedora的一个实例启动并运行。具有sudo访问权限的用户帐户。您的移动设备上的第三方身份验证器应用程序(例如Authy)。

在您开始讨论之前,我强烈建议您在直接访问Fedora的物理计算机上测试。如果出现问题,您能够直接登录到计算机,可以更方便解决问题。

安装

第一步是安装Google身份验证器。打开终端窗口并发出以下命令:

sudo dnf install google-authenticator nano -y

安装完成后,使用以下命令运行该工具:

google-authenticator

您将被问到以下问题:

Do you want authentication tokens to be time-based (y/n) y

Do you want me to update your “/home/user/.google_authenticator” file (y/n)? y

然后,应用程序将显示QR码,您需要扫描到Authy(在移动设备上)。您还将获得一个密码列表,您需要将其复制并保存在一个安全的秘密位置。成功扫描QR码并保存恢复代码后,您将再被问到三个问题(同样,每个问题都回答“是”)。

配置SSH

在此之前,请确保您可以SSH到Fedora计算机。开箱即用,SSH守护程序可能未运行,因此请使用以下命令启动并启用它:

sudo systemctl start sshd

sudo systemctl enable sshd

SSH运行并启用后,请确保从您计划用于获取远程访问权限的任何/所有计算机上将SSH密钥复制到此计算机(用于SSH密钥身份验证)。这可以通过从需要访问的每台机器运行以下命令来完成:

ssh-copy-id USER @ FEDORA_IP

USER是Fedora机器上的用户名,FEDORA_IP是Fedora机器的IP地址。

一旦您能够使用SSH密钥身份验证SSH到Fedora计算机,就可以配置SSH以使用双因素身份验证。从终端窗口(在Fedora机器上),发出命令:

sudo nano /etc/pam.d/sshd

注释掉第一行(通过在开头添加#symbole)。该行现在看起来像:

#auth substack password-auth

在文件的底部,添加以下行:

auth sufficient pam_google_authenticator.so

保存并关闭该文件。

接下来,我们需要配置SSH守护进程。发出命令:

sudo nano / etc / ssh / sshd_config

首先,将ChallengeResponseAuthentication从no更改为yes,如下所示:

ChallengeResponseAuthentication是的

接下来,将PasswordAuthentication更改为no,如下所示:

PasswordAuthentication no

最后,将以下内容添加到该文件的底部:

AuthenticationMethods publickey,password publickey,keyboard-interactive

保存并关闭文件。

使用以下命令重新启动SSH守护程序:

sudo systemctl restart sshd

登录

准备好登录。从您的一台客户端计算机上,打开终端窗口并发出命令:

ssh USER @ FEDORA_IP

USER是Fedora机器上的用户名,FEDORA_IP是Fedora机器的IP地址。系统将提示您输入验证码(图A),您将从移动验证应用中检索该验证码。

Linux中为SSH启用双因素身份验证

图A:我们提供验证码的SSH提示。

输入代码后,您应该可以访问该计算机(因为您设置了SSH密钥身份验证)。

恭喜,您现在可以为Fedora机器设置双因素身份验证。每当有人尝试使用SSH登录该服务器或桌面时,如果没有您的移动身份验证应用程序生成的双因素身份验证代码,他们将无法访问。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233240.html原文链接:https://javaforall.net

(0)
上一篇 2025年8月4日 下午7:01
下一篇 2025年8月4日 下午7:22


相关推荐

  • 内网IP地址段_专用内网ip

    内网IP地址段_专用内网iptcp/ip协议中,专门保留了三个IP地址区域作为私有地址,其地址范围如下:10.0.0.0/8:10.0.0.0~10.255.255.255172.16.0.0/12:172.16.0.0~172.31.255.255192.168.0.0/16:192.168.0.0~192.168.255.255

    2025年11月16日
    4
  • 计算机操作系统(第3版)课后习题答案(完整版)

    计算机操作系统(第3版)课后习题答案(完整版)第一章1.设计现代OS的主要目标是什么?答:(1)有效性(2)方便性(3)可扩充性(4)开放性2.OS的作用可表现在哪几个方面?答:(1)OS作为用户与计算机硬件系统之间的接口(2)OS作为计算机系统资源的管理者(3)OS实现了对计算机资源的抽象3.为什么说OS实现了对计算机资源的抽象?答:OS首先在裸机上覆盖一层I/O设备管理软件,实现了对计算机硬件操作的第

    2022年5月30日
    144
  • git版本号管理工具的上手

    git版本号管理工具的上手

    2021年11月24日
    53
  • PHP7.2 CURL扩展

    PHP7.2 CURL扩展1 在 php ini 中找到 extension php curl dll 去掉前面的 2 在 php ini 中找到 extension dir ext 去掉前面的 改为 extension dir ext https blog csdn net gianttj article details

    2026年3月26日
    2
  • mysql 取模分区_MySQL分区

    mysql 取模分区_MySQL分区分表是将一个大表按照一定的规则分解成多张具有独立存储空间的实体表,app读写的时候根据事先定义好的规则得到对应的子表名,然后去操作它。而分区是将数据分段划分在多个位置存放,分区后,表面上还是一张表,但数据散列到多个位置了。app读写的时候操作的还是大表名字,db自动去组织分区的数据。分区类型主要有range、list、hash、key以常规hash举例说明分区是如何创建的常规hash是取模运算创建…

    2022年4月29日
    53
  • YUI中js的继承示例

    YUI中js的继承示例无标题文档一个简单的例子。在这个例子中,可以看到,用var定义的私有变量,是不能被继承的。所有能被继承的,一定是通过this关键字,在内在地址中和这个对象的地址捆在一起的变量。因为复合对象传的不是值

    2022年7月4日
    24

发表回复

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

关注全栈程序员社区公众号