网站首页 > 博客文章 正文
概述
在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服务端系统,如下图所示;
总结
以上分享,希望各位小伙伴有所收获,欢迎各位点赞、收藏和指正。
猜你喜欢
- 2024-10-10 Nutch-Hadoop-MongoDB搭建分布式爬虫
- 2024-10-10 OpenSSH更新至8.0,修复存在35年的安全漏洞
- 2024-10-10 [python] 基于paramiko库操作远程服务器
- 2024-10-10 利用Zabbix监控系统SSH方式检测远程目标主机
- 2024-10-10 手工方式IPSec VPN配置保障单位与分支之间的数据安全
- 2024-10-10 SSH 简介:安全远程访问的利器(安全远程登录协议ssh)
- 2024-10-10 [ Laravel 5.6 文档 ] 快速入门 —— 重量级开发环境:Homestead
- 2024-10-10 快速上手:Docker环境下的WordPress安装全攻略
- 2024-10-10 阿里云服务器Centos7.3安装Git(阿里云服务器centos装桌面)
- 2024-10-10 如何使用ssh密钥登录远程服务器(如何使用ssh密钥登录远程服务器账号)
你 发表评论:
欢迎- 367℃用AI Agent治理微服务的复杂性问题|QCon
- 358℃初次使用IntelliJ IDEA新建Maven项目
- 356℃手把手教程「JavaWeb」优雅的SpringMvc+Mybatis整合之路
- 351℃Maven技术方案最全手册(mavena)
- 348℃安利Touch Bar 专属应用,让闲置的Touch Bar活跃起来!
- 346℃InfoQ 2024 年趋势报告:架构篇(infoq+2024+年趋势报告:架构篇分析)
- 345℃IntelliJ IDEA 2018版本和2022版本创建 Maven 项目对比
- 342℃从头搭建 IntelliJ IDEA 环境(intellij idea建包)
- 最近发表
- 标签列表
-
- powershellfor (55)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)