百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

Windows10操作系统部署SSH服务-基于密钥的身份验证

ztj100 2024-12-08 20:05 23 浏览 0 评论

概述

在Windows 环境中的大多数身份验证都基于用户名-密码对完成的,很容易受到暴力攻击入侵。相对于Linux 环境通常使用公钥/私钥对来驱动身份验证,这不要求使用可推测的密码。“私钥”文件和“公钥”文件采用非对称加密算法生成,私钥文件等效于密码,用于解密由公钥加密的数据。

基于密钥的身份验证的工具的具体实现逻辑是:

客户端:ssh-keygen:生成安全的密钥,公钥和私钥;

客户端:ssh-agent 和 ssh-add:安全地存储私钥,加载私钥后,客户端本地系统可删除私钥文件;

客户端:scp 和 sftp:客户端把公钥上传到SSH服务端。

那么,Windows10系统该如何实现基于密钥的身份验证呢?本期文章予以揭晓。

生成安全的密钥文件

客户端系统生成私钥和公钥文件。

打开系统命令提示符,输入命令“ssh-keygen -t ed25519”;

按 Enter 来接受默认值,或指定要在其中生成密钥的路径和/或文件名,然后,系统会提示你使用密码来加密你的私钥文件;

直接按 Enter默认不设置密码,建议使用密码加密私钥文件,从而实现基于密码与密钥文件的双因子身份验证。

如下图所示:

未设置密码加密私钥文件;

生成的私钥文件保存的位置:C:\Users\Administrator/.ssh/Tid_ed25519;

生成的公钥文件保存的位置:C:\Users\Administrator/.ssh/Tid_ed25519.pub;

启动ssh-agent服务并加载私钥

客户端系统启动ssh-agent服务并加载私钥。

打开命令提示符【CMD】,输入命令services.msc打开服务,如下图所示;

定位到OpenSSH Authentication Agent并启动该服务。

以管理员权限打开命令提示符【CMD】,输入命令ssh-add C:\Users\Administrator\.ssh\Tid_ed25519加载私钥,如下图所示;

将私钥加载到客户端上的 ssh-agent 后,ssh-agent 会自动检索本地私钥并将其传递给 SSH 客户端。

Tips:

建议将私钥备份到一个安全位置,待ssh-agent将其加载后,即可把它从本地系统中删除。此外,使用强算法Ed25519是无法从代理中检索私钥。

把公钥上传到SSH服务端

客户端系统把生成的公钥文件上传到SSH服务端系统。

对于SSH服务端系统的管理员账户,将公钥(Tid_ed25519.pub)的内容需放置在SSH服务端系统上的一个名为 administrators_authorized_key的文本文件中,该文件位于 C:\ProgramData\ssh\,如下图所示;

关键命令释义:

#定义变量authorizedKey,把公钥文件赋值给它

$authorizedKey = Get-Content -Path C:\Users\Administrator\.ssh\Tid_ed25519.pub

#定义变量remotePowershell,并调用变量authorizedKey

$remotePowershell = "powershell Add-Content -Force -Path $env:ProgramData\ssh\administrators_authorized_keys -Value '$authorizedKey';icacls.exe ""$env:ProgramData\ssh\administrators_authorized_keys"" /inheritance:r /grant ""Administrators:F"" /grant ""SYSTEM:F"""

#登录SSH服务端系统并调用变量remotePowershell

ssh administrator@192.168.1.10 $remotePowershell

测试验证

打开命令提示符【CMD】,输入命令“ssh 192.168.1.10”,即可登录SSH服务端系统,如下图所示;

总结

以上分享,希望各位小伙伴有所收获,欢迎各位点赞、收藏和指正。

相关推荐

再说圆的面积-蒙特卡洛(蒙特卡洛方法求圆周率的matlab程序)

在微积分-圆的面积和周长(1)介绍微积分方法求解圆的面积,本文使用蒙特卡洛方法求解圆面积。...

python编程:如何使用python代码绘制出哪些常见的机器学习图像?

专栏推荐...

python创建分类器小结(pytorch分类数据集创建)

简介:分类是指利用数据的特性将其分成若干类型的过程。监督学习分类器就是用带标记的训练数据建立一个模型,然后对未知数据进行分类。...

matplotlib——绘制散点图(matplotlib散点图颜色和图例)

绘制散点图不同条件(维度)之间的内在关联关系观察数据的离散聚合程度...

python实现实时绘制数据(python如何绘制)

方法一importmatplotlib.pyplotaspltimportnumpyasnpimporttimefrommathimport*plt.ion()#...

简单学Python——matplotlib库3——绘制散点图

前面我们学习了用matplotlib绘制折线图,今天我们学习绘制散点图。其实简单的散点图与折线图的语法基本相同,只是作图函数由plot()变成了scatter()。下面就绘制一个散点图:import...

数据分析-相关性分析可视化(相关性分析数据处理)

前面介绍了相关性分析的原理、流程和常用的皮尔逊相关系数和斯皮尔曼相关系数,具体可以参考...

免费Python机器学习课程一:线性回归算法

学习线性回归的概念并从头开始在python中开发完整的线性回归算法最基本的机器学习算法必须是具有单个变量的线性回归算法。如今,可用的高级机器学习算法,库和技术如此之多,以至于线性回归似乎并不重要。但是...

用Python进行机器学习(2)之逻辑回归

前面介绍了线性回归,本次介绍的是逻辑回归。逻辑回归虽然名字里面带有“回归”两个字,但是它是一种分类算法,通常用于解决二分类问题,比如某个邮件是否是广告邮件,比如某个评价是否为正向的评价。逻辑回归也可以...

【Python机器学习系列】拟合和回归傻傻分不清?一文带你彻底搞懂

一、拟合和回归的区别拟合...

推荐2个十分好用的pandas数据探索分析神器

作者:俊欣来源:关于数据分析与可视化...

向量数据库:解锁大模型记忆的关键!选型指南+实战案例全解析

本文较长,建议点赞收藏,以免遗失。更多AI大模型应用开发学习视频及资料,尽在...

用Python进行机器学习(11)-主成分分析PCA

我们在机器学习中有时候需要处理很多个参数,但是这些参数有时候彼此之间是有着各种关系的,这个时候我们就会想:是否可以找到一种方式来降低参数的个数呢?这就是今天我们要介绍的主成分分析,英文是Princip...

神经网络基础深度解析:从感知机到反向传播

本文较长,建议点赞收藏,以免遗失。更多AI大模型应用开发学习视频及资料,尽在...

Python实现基于机器学习的RFM模型

CDA数据分析师出品作者:CDALevelⅠ持证人岗位:数据分析师行业:大数据...

取消回复欢迎 发表评论: