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

Impacket工具中的横向渗透利器及其使用场景对比详解

在渗透测试中,横向移动(Lateral Movement)是指攻击者在获得一个系统的控制权限后,通过网络进一步渗透到其他系统的过程。Impacket 是一款强大的渗透测试工具集,提供了多种实现横向渗透的脚本,常见的工具包括 psexec.pysmbexec.pyatexec.pydcomexec.pywmiexec.py。尽管这些工具都可以执行远程命令,但它们在工作原理、依赖的服务以及使用条件上有显著差异。下面我们将对这些工具进行详细的对比分析。


1. psexec.py

psexec.py 是 Impacket 中非常经典的工具,仿照了 Microsoft 的 PsExec 工具。它通过 SMB(Server Message Block)协议和 RPC(远程过程调用)服务实现远程命令执行。具体流程是,psexec.py 在目标主机上通过 SMB 上传一个可执行文件,然后利用 RPC 启动该文件作为服务,从而执行命令。

工作原理

  • SMB 连接: psexec.py 首先尝试通过 SMB 协议连接到目标主机。
  • 文件上传: 一旦连接成功,它会将一个可执行文件上传到目标系统的共享文件夹(如 ADMIN$)。
  • 服务启动: 之后,psexec.py 会利用 RPC 启动该服务,从而在目标系统上执行远程命令。

依赖服务

  • SMB 服务: 需要目标主机开放 SMB 服务(通常是 TCP 445)。
  • RPC 服务: 依赖于 RPC(远程过程调用)来启动服务。

端口需求

  • TCP 445: 用于 SMB 通信,这是 psexec.py 的核心端口。
  • TCP 139: 在早期的 SMB 版本中,可能使用这个端口进行通信,但现代 SMB 使用 TCP 445。

优缺点

  • 优点: 操作简单,且不依赖于目标主机上的额外服务,只要 SMB 和 RPC 可用即可。且以管理员权限登录后直接以 SYSTEM 权限执行命令。
  • 缺点: 容易被防火墙和入侵检测系统检测到,因为上传文件和服务启动的行为很容易暴露。尤其是在目标环境中开启了 SMB 端口的安全监控时,攻击行为会被察觉。

2. smbexec.py

smbexec.py 是 Impacket 中的另一个工具,功能与 psexec.py 相似,但工作方式略有不同。它同样依赖于 SMB 协议来执行远程命令,但与 psexec.py 不同,smbexec.py 不需要上传可执行文件。相反,它利用共享资源(如 ADMIN$C$)直接在目标主机上执行命令。这使得 smbexec.py 相比 psexec.py 更加隐蔽。

工作原理

  • SMB 连接: smbexec.py 通过 SMB 协议连接到目标系统。
  • 共享资源: 一旦连接成功,它通过目标主机上的共享资源(如 ADMIN$C$)来执行命令。
  • 远程命令执行: 命令通过 SMB 共享直接在目标系统上执行,而不需要上传任何可执行文件。

依赖服务

  • SMB 服务: smbexec.py 完全依赖于 SMB 服务来实现命令执行。
  • 无 RPC 服务依赖:psexec.py 不同,smbexec.py 不依赖于 RPC 服务来启动进程或服务。

端口需求

  • TCP 445: 同样需要通过 TCP 445 端口进行 SMB 通信。
  • TCP 139: 在某些情况下,如果目标系统使用较旧的 SMB 协议,可能还会使用 TCP 139。

优缺点

  • 优点: 相比 psexec.pysmbexec.py 不需要上传文件,减少了被检测到的风险。它利用现有的共享资源直接执行命令,这使得攻击行为更加隐蔽。
  • 缺点: 依赖目标系统的共享权限。如果目标系统的共享权限配置严格,可能无法成功执行命令。此外,某些安全工具可能会对共享资源的异常访问进行监控。

3. atexec.py

atexec.py 是另一个用于远程执行命令的工具,但它与 psexec.pysmbexec.py 的工作原理有所不同。它通过 Windows 的任务计划程序(Task Scheduler)服务来执行命令。atexec.py 将命令作为计划任务添加到目标机器中,然后立即执行。

工作原理

  • 任务计划程序: atexec.py 将命令注册为计划任务。
  • 立即执行: 任务一旦添加到目标系统中,会立即启动执行命令。

依赖服务

  • SMB 服务: 需要通过 SMB 协议与目标主机建立连接。
  • RPC 服务: 需要 RPC 服务来与目标系统的任务计划服务进行交互。

端口需求

  • TCP 445 和 TCP 135: 需要通过这些端口与目标主机的 SMB 和 RPC 服务进行通信。

优缺点

  • 优点: 任务计划程序是 Windows 系统中常用的工具,执行命令的过程相对隐蔽,且不需要上传额外的文件。
  • 缺点: 需要目标系统的任务调度服务可用,而且某些目标系统可能会对计划任务进行严格的安全控制。

4. dcomexec.py

dcomexec.py 是通过 DCOM(分布式组件对象模型)协议进行远程命令执行的工具。它使用已注册的 DCOM 应用程序(如 MMC20.ApplicationShellWindows)来执行命令。由于 DCOM 协议较少用于渗透测试,它的攻击行为更难被发现。

工作原理

  • DCOM 协议: dcomexec.py 通过 DCOM 协议与目标主机建立连接,并利用已注册的 DCOM 应用程序执行命令。

依赖服务

  • DCOM 服务: 需要目标系统启用 DCOM 服务。
  • RPC 服务: 需要通过 RPC 与目标系统进行通信。

端口需求

  • TCP 445 和 TCP 135: 需要这两个端口来与目标主机的 SMB 和 RPC 服务进行通信。
  • 高端端口: DCOM 可能会使用动态分配的高端端口(49152-65535)进行通信。

优缺点

  • 优点: DCOM 协议较为隐蔽,不容易被传统防火墙或入侵检测系统监测到。
  • 缺点: 依赖于 DCOM 服务,且目标系统可能会有防御措施。

5. wmiexec.py

wmiexec.py 是通过 Windows 管理工具(WMI)来执行远程命令的工具。WMI 是 Windows 系统的强大管理工具,允许管理员和攻击者远程管理系统。wmiexec.py 利用 WMI 来执行命令,是一种极为隐蔽的渗透工具。

工作原理

  • WMI 协议: 通过 WMI 协议执行命令,不需要上传可执行文件。
  • 远程命令: 命令通过 WMI 在目标主机上执行,避免了传统的文件上传和服务创建。

依赖服务

  • WMI 服务: 需要目标系统启用 WMI 服务。
  • RPC 服务: 需要通过 RPC 与目标系统进行通信。

端口需求

  • TCP 445 和 TCP 135: 用于与 SMB 和 RPC 服务进行通信。
  • 高端端口: WMI 可能会使用动态分配的高端端口(49152-65535)。

优缺点

  • 优点: 非常隐蔽,不容易被防火墙或入侵检测系统检测到。
  • 缺点: 需要目标系统启用 WMI 服务,并且某些配置可能限制远程命令执行。

结论

不同的工具有不同的应用场景和优缺点。psexec.pysmbexec.py 都依赖于 SMB 协议来实现远程命令执行,但前者需要上传文件,后者则通过共享资源直接执行命令。atexec.py 通过任务计划服务实现远程执行,适用于不希望留下文件痕迹的情况;dcomexec.pywmiexec.py 则依赖于较为隐蔽的协议(DCOM 和 WMI),适用于需要绕过传统安全检测的场景。选择合适的工具应基于目标环境的安全防护措施、可用端口以及需要绕过的防火墙策略来做出决定。

相关文章:

Impacket工具中的横向渗透利器及其使用场景对比详解

在渗透测试中,横向移动(Lateral Movement)是指攻击者在获得一个系统的控制权限后,通过网络进一步渗透到其他系统的过程。Impacket 是一款强大的渗透测试工具集,提供了多种实现横向渗透的脚本,常见的工具包括…...

基于java,SpringBoot和Vue的医院药房药品管理系统设计

摘要 随着医疗行业信息化的快速发展,高效、精准的医院药房药品管理对于提升医疗服务质量和医院运营效率至关重要。本文基于 Java 语言,采用 SpringBoot 框架和 Vue 框架进行医院药房药品管理系统的设计与研究。该系统以 SpringBoot 作为后端开发框架&am…...

MQ保证消息的顺序性

在消息队列(MQ)中保证消息的顺序性是一个常见的需求,尤其是在需要严格按顺序处理业务逻辑的场景(例如:订单创建 → 支付 → 发货)。 一、消息顺序性被破坏的原因 生产者异步/并行发送:消息可能…...

cmake、CMakeLists.txt、make、ninja

文章目录 一、概念0.cmake官网1.什么是cmake2.为什么使用cmake3.CMakeLists.txt 二、CMakeLists.txt语法:如何编写CMakeLists.txt,语法详解(0)语法基本原则(1)project关键字(2)set关键字(3)message关键字(4)add_executable关键字(5)add_subdirectory关键…...

数据结构与算法 计算机组成 八股

文章目录 数据结构与算法数组与链表的区别堆的操作红黑树定义及其原理 计算机组成int和uint的表示原码反码补码移码的定义?为什么用补码? 数据结构与算法 数组与链表的区别 堆的操作 红黑树定义及其原理 计算机组成 int和uint的表示 原码反码补码移…...

RoboBrain:从抽象到具体的机器人操作统一大脑模型

25年2月来自北大、北京智源、中科院自动化所等的论文“RoboBrain: A Unified Brain Model for Robotic Manipulation from Abstract to Concrete”。 目前的多模态大语言模型(MLLM) 缺少三项必备的机器人大脑能力:规划能力,将复杂…...

算法 之 前缀和 与 滑动窗口 与 背包问题 的差异(子数组之和为k问题)

文章目录 使用前缀和哈希表560.和为K的子数组525.连续数组2588.统计美丽子数组数目 子数组的定义是原来的数组当中连续的非空的序列,而我们的背包问题的选与不选的情况,对应的是这个非连续的情况,那么这种情况就要注意当然啦,对于线性的时间内…...

微电网协调控制器ACCU-100 分布式光伏 光储充一本化

安科瑞 华楠 18706163979 应用范围: 分布式光伏、微型风力发电、工商业储能、光储充一体化电站、微电网等领域。 主要功能: 数据采集:支持串口、以太网等多通道实时运行,满足各类风电与光伏逆变器、储能等 设备接入&#xff…...

IDEA入门及常用快捷键

IDEA是java常用的IDE。当run一个.java文件时,其实是经历了先编译为.class,再运行的过程。 在project文件夹中,out文件夹存储编译的.class文件,src文件夹存储.java代码文件。 设置自动导包 快捷键: 格式化快捷键&…...

electron打包结构了解

Electron 应用打包后的文件结构和内容取决于你使用的打包工具(如 electron-builder、electron-packager 等)以及目标操作系统(Windows、macOS、Linux)。以下是典型 Electron 应用打包后的文件结构和关键组成部分: 1. 基…...

03.06 QT

一、使用QSlider设计一个进度条&#xff0c;并让其通过线程自己动起来 程序代码&#xff1a; <1> Widget.h: #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QThread> #include "mythread.h"QT_BEGIN_NAMESPACE namespace Ui {…...

Python中的常用库

一、collections collections是 Python 标准库中的一个模块&#xff0c;提供了一些专门的容器数据类型&#xff0c;能够帮助你更高效地处理常见的数据结构操作。 1、Counter Counter 是一个字典的子类&#xff0c;用于计数可哈希对象。它会统计对象的出现次数&#xff0c;并…...

马尔科夫不等式和切比雪夫不等式

前言 本文隶属于专栏《机器学习数学通关指南》&#xff0c;该专栏为笔者原创&#xff0c;引用请注明来源&#xff0c;不足和错误之处请在评论区帮忙指出&#xff0c;谢谢&#xff01; 本专栏目录结构和参考文献请见《机器学习数学通关指南》 正文 统计概率的利剑&#xff1a;掌…...

护照阅读器在汽车客运站流程中的应用

在汽车客运站的日常运营里&#xff0c;如何高效服务旅客、保障出行安全是工作重点。护照阅读器作为精准身份识别的得力工具&#xff0c;在客运站的多个关键流程&#xff0c;如自助购票、柜台购票、安检以及行李托运中&#xff0c;发挥着不可小觑的作用&#xff0c;有力地提升了…...

CentOS 7 安装Nginx-1.26.3

无论安装啥工具、首先认准了就是官网。Nginx Nginx官网下载安装包 Windows下载&#xff1a; http://nginx.org/download/nginx-1.26.3.zipLinxu下载 wget http://nginx.org/download/nginx-1.26.3.tar.gzLinux安装Nginx-1.26.3 安装之前先安装Nginx依赖包、自行选择 yum -y i…...

Unity 使用NGUI制作无限滑动列表

原理&#xff1a; 复用几个子物体&#xff0c;通过子物体的循环移动实现&#xff0c;如下图 在第一个子物体滑动到超出一定数值时&#xff0c;使其放到最下方 --------------------------------------------------------------》 然后不停的循环往复&#xff0c;向下滑动也是这…...

linux中断调用流程(arm)

文章目录 ARM架构下Linux中断处理全流程解析&#xff1a;从硬件触发到驱动调用 ⚡**一、中断触发与硬件层响应** &#x1f50c;**1. 设备触发中断** &#x1f4e1; **二、CPU阶段&#xff1a;异常入口与上下文处理** &#x1f5a5;️**1. 异常模式切换** &#x1f504;**2. 跳转…...

基于Matlab的多目标粒子群优化

在复杂系统的设计、决策与优化问题中&#xff0c;常常需要同时兼顾多个相互冲突的目标&#xff0c;多目标粒子群优化&#xff08;MOPSO&#xff09;算法应运而生&#xff0c;作为群体智能优化算法家族中的重要成员&#xff0c;它为解决此类棘手难题提供了高效且富有创新性的解决…...

【网络安全】——协议逆向与频繁序列提取:从流量中解码未知协议

目录 引言 一、为什么要结合频繁序列提取&#xff1f; 二、四步融合分析法 步骤1&#xff1a;原始流量采集与预处理 步骤2&#xff1a;多粒度序列模式挖掘 层1&#xff1a;单包内字节级频繁项 层2&#xff1a;跨数据包的行为序列 步骤3&#xff1a;关键字段定位与结构假…...

CSS 中等比例缩放的演变:从传统技巧到 aspect-ratio 属性

CSS 中等比例缩放的演变&#xff1a;从传统技巧到 aspect-ratio 属性 在响应式网页设计和多设备兼容成为主流的今天&#xff0c;如何实现元素的等比例缩放成为前端开发中一个重要的课题。无论是图片、视频还是其他容器&#xff0c;都常常需要保持固定的宽高比&#xff0c;以便…...

【人工智能】神经网络的优化器optimizer(二):Adagrad自适应学习率优化器

一.自适应梯度算法Adagrad概述 Adagrad&#xff08;Adaptive Gradient Algorithm&#xff09;是一种自适应学习率的优化算法&#xff0c;由Duchi等人在2011年提出。其核心思想是针对不同参数自动调整学习率&#xff0c;适合处理稀疏数据和不同参数梯度差异较大的场景。Adagrad通…...

Android15默认授权浮窗权限

我们经常有那种需求&#xff0c;客户需要定制的apk集成在ROM中&#xff0c;并且默认授予其【显示在其他应用的上层】权限&#xff0c;也就是我们常说的浮窗权限&#xff0c;那么我们就可以通过以下方法在wms、ams等系统服务的systemReady()方法中调用即可实现预置应用默认授权浮…...

在WSL2的Ubuntu镜像中安装Docker

Docker官网链接: https://docs.docker.com/engine/install/ubuntu/ 1、运行以下命令卸载所有冲突的软件包&#xff1a; for pkg in docker.io docker-doc docker-compose docker-compose-v2 podman-docker containerd runc; do sudo apt-get remove $pkg; done2、设置Docker…...

什么是Ansible Jinja2

理解 Ansible Jinja2 模板 Ansible 是一款功能强大的开源自动化工具&#xff0c;可让您无缝地管理和配置系统。Ansible 的一大亮点是它使用 Jinja2 模板&#xff0c;允许您根据变量数据动态生成文件、配置设置和脚本。本文将向您介绍 Ansible 中的 Jinja2 模板&#xff0c;并通…...

力扣-35.搜索插入位置

题目描述 给定一个排序数组和一个目标值&#xff0c;在数组中找到目标值&#xff0c;并返回其索引。如果目标值不存在于数组中&#xff0c;返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 class Solution {public int searchInsert(int[] nums, …...

中医有效性探讨

文章目录 西医是如何发展到以生物化学为药理基础的现代医学&#xff1f;传统医学奠基期&#xff08;远古 - 17 世纪&#xff09;近代医学转型期&#xff08;17 世纪 - 19 世纪末&#xff09;​现代医学成熟期&#xff08;20世纪至今&#xff09; 中医的源远流长和一脉相承远古至…...

JVM虚拟机:内存结构、垃圾回收、性能优化

1、JVM虚拟机的简介 Java 虚拟机(Java Virtual Machine 简称:JVM)是运行所有 Java 程序的抽象计算机,是 Java 语言的运行环境,实现了 Java 程序的跨平台特性。JVM 屏蔽了与具体操作系统平台相关的信息,使得 Java 程序只需生成在 JVM 上运行的目标代码(字节码),就可以…...

RSS 2025|从说明书学习复杂机器人操作任务:NUS邵林团队提出全新机器人装配技能学习框架Manual2Skill

视觉语言模型&#xff08;Vision-Language Models, VLMs&#xff09;&#xff0c;为真实环境中的机器人操作任务提供了极具潜力的解决方案。 尽管 VLMs 取得了显著进展&#xff0c;机器人仍难以胜任复杂的长时程任务&#xff08;如家具装配&#xff09;&#xff0c;主要受限于人…...

Redis:现代应用开发的高效内存数据存储利器

一、Redis的起源与发展 Redis最初由意大利程序员Salvatore Sanfilippo在2009年开发&#xff0c;其初衷是为了满足他自己的一个项目需求&#xff0c;即需要一个高性能的键值存储系统来解决传统数据库在高并发场景下的性能瓶颈。随着项目的开源&#xff0c;Redis凭借其简单易用、…...

在鸿蒙HarmonyOS 5中使用DevEco Studio实现企业微信功能

1. 开发环境准备 ​​安装DevEco Studio 3.1​​&#xff1a; 从华为开发者官网下载最新版DevEco Studio安装HarmonyOS 5.0 SDK ​​项目配置​​&#xff1a; // module.json5 {"module": {"requestPermissions": [{"name": "ohos.permis…...