CS功能分析-DotNet

这是[信安成长计划]的第 14 篇文章

0x00 目录

0x01 DotNet功能分析

0x02 DotNet功能执行

0x03 写在最后

在前两篇文章中,已经探讨了 CS 中的一种功能执行方式 RDI,本文将深入分析另一种非常重要的功能执行方式——DotNet。

0x01 DotNet功能分析

CobaltStrike 提供了执行任意 DotNet 程序的方案,利用了名为 invokeassembly 的 DLL 来加载和执行传递的 DotNet 功能。这种方法由 ExecuteAssemblyJob 提供支持,与 RDI 不同的是,它继承自 JobSimple 类。

CS功能分析-DotNet与 RDI 类似,它也需要处理一些必要的方法。

CS功能分析-DotNet在实际执行时,它会直接运行 ExecuteAssemblyJob 的 spawn 方法。

CS功能分析-DotNet首先获取 invokeassembly.dll,并找到它的 ReflectiveLoader 函数,随后开始构建任务。

CS功能分析-DotNet接着会进行一些设置操作。

CS功能分析-DotNet在 fix 中,会处理一些 amsi 相关的内容。

CS功能分析-DotNet接下来是一个重要的步骤,获取参数。

CS功能分析-DotNet在这里会将 this.file 和 this.args 组合在一起。

极简智能王 极简智能王

极简智能- 智能聊天AI绘画,还可以创作、编写、翻译、写代码等多种功能,满足用户生活和工作的多方面需求

极简智能王 33 查看详情 极简智能王

CS功能分析-DotNet这两个元素正是我们要执行的 DotNet 程序和参数,因此 CS 将我们要执行的内容作为参数进行传输,最后交给 invokeassembly 来执行。

CS功能分析-DotNet之后就是任务的构建和发送。

CS功能分析-DotNet0x02 DotNet功能执行

在执行 DotNet 功能时,忽略前面的处理操作,直接关注执行部分。

根据之前对 RDI 的分析,很容易就能区分出进程创建的位置,其中的操作基本一致。

CS功能分析-DotNet直接进入函数执行,这里包含了各种执行方式和加载运行。

CS功能分析-DotNet之后,执行权限就移交给了 invokeassembly。

CS功能分析-DotNet继续追踪下去的意义不大,主要是调用接口来加载 DotNet 程序集,其中使用的技术是已经开源的 Hosting CLR,可以参考以下文章进行阅读:

https://www.php.cn/link/133232fc800034e36792956ebea38deb

https://www.php.cn/link/418bf1ce1437adeeb5d0352fcd92b1d2

0x03 写在最后

与 RDI 不同的是,我们不需要在 DotNet 中处理管道相关的内容,这些由 beacon 和 invokeassembly 处理。因为 DotNet 是由我们传进去的,而 RDI 的功能不支持像 DotNet 这样直接调用。我们通过二次开发的方式使用,就需要按照规定好的方式进行处理才行。

以上就是CS功能分析-DotNet的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 07:37:56
下一篇 2025年11月8日 07:39:37

相关推荐

  • python怎么撤回

    如何在 Python 中撤回代码提交?撤回暂存区中的修改:使用 “git reset HEAD” 命令。撤回已提交的更改:a. 查看提交历史并找到要撤回的提交哈希值。b. 执行 “git reset –hard ” 命令。 如何用 Pyth…

    2025年12月13日
    000
  • python怎么快速注释

    Python 快速注释有四种方法:单行注释(# 符号)、多行注释(三个单引号或双引号符号)、注释装饰器(@dataclass)、自动注释工具(如 Google AutoDoc、Mypy、pyannotate)。最佳实践是为公共方法和类编写描述性的文档字符串,并使用 Markdown 格式化进行注释。…

    2025年12月13日
    000
  • python怎么保留一位小数

    要使用 Python 保留一位小数,可以使用 round() 函数:number:要四舍五入的数字ndigits:保留的小数位数(正数保留小数位,负数四舍五入到最接近的 10 的 ndigits 次方,0 四舍五入到整数) 如何使用 Python 保留一位小数 要使用 Python 保留一位小数,可…

    2025年12月13日
    000
  • python编辑器怎么用

    Python 编辑器是一种用于编写、编辑和调试 Python 代码的软件。常见的有 PyCharm、Visual Studio Code、Sublime Text 和 IDLE。使用步骤包括创建项目、编写代码、运行代码和调试代码。选择合适的编辑器取决于需求,初学者建议 IDLE 或 Visual S…

    2025年12月13日
    000
  • python怎么撤销

    在 Python 中撤销操作的方法有:按 Ctrl + Z 撤销最近的命令。使用 undo() 函数撤销对文本的更改。使用版本控制系统(如 Git)撤销代码更改。使用 IDE 内置的撤销功能。使用 __del__() 方法在对象销毁时撤销其操作。 如何撤销 Python 操作 在 Python 中,…

    2025年12月13日
    000
  • python字符串函数怎么用

    Python 字符串函数提供广泛的功能,包括基本函数(如转换、大小写转换)、格式化函数(如格式化、连接),搜索函数(如查找、索引),以及其他函数(如检查字符类型、空格)。 Python 字符串函数 字符串函数是 Python 中用于处理字符串的强大工具。它们允许您执行各种操作,从格式化和连接到搜索和…

    2025年12月13日
    000
  • python怎么保留小数

    在 Python 中,保留小数可通过字符串格式化(使用 “format()” 函数)和数学库函数(”round()” 和 “round()”) 实现,其中 “format()” 用于保留指定位数的小数,而…

    2025年12月13日
    000
  • python中round怎么输出

    Python 中的 round() 函数输出格式根据结果类型而定:整数输出为整数,浮点数输出为浮点数,精度取决于四舍五入位数(ndigits)。ndigits 的值决定了四舍五入的位数或 10 的倍数。 Python 中 round() 的输出格式 Python 中的 round() 函数用于四舍五…

    2025年12月13日
    000
  • pycharm的git怎么使用

    在 PyCharm 中使用 Git 的步骤如下:设置 Git,包括路径、用户和电子邮件。初始化 Git 存储库,为存储库指定名称和描述。添加已修改文件并提交更改,输入提交描述。推送更改到远程存储库,首次推送时需要设置远程存储库。拉取远程存储库的更改。查看提交历史,双击提交查看其详细信息。创建和合并分…

    2025年12月13日
    000
  • pycharm怎么用git

    在 PyCharm 中使用 Git 需遵循以下步骤:安装 Git在 PyCharm 中配置 Git 集成克隆或创建仓库提交本地更改至暂存区推送本地更改至远程仓库从远程仓库拉取更改使用分支管理独立开发副本合并分支并解决冲突 如何使用 PyCharm 中的 Git 第一步:安装 Git 在使用 PyCh…

    2025年12月13日
    000
  • pycharm怎么保存代码

    在 PyCharm 中保存代码的方法:按快捷键 Ctrl + S(Windows/Linux)、⌘ + S(macOS);点击菜单栏文件 (File) > 保存 (Save);点击文件 (File) > 另存为 (Save As) 保存为新文件;在设置中启用自动保存功能。 如何在 PyC…

    2025年12月13日
    000
  • python怎么用别人的代码

    如何使用他人的 Python 代码?查找代码库:在 PyPI 和 GitHub 等平台上查找所需代码。安装代码:使用 pip 或克隆 GitHub 仓库进行安装。导入模块:在脚本中使用 import 语句导入已安装的模块。使用代码:访问模块中的函数和类。(可选)调整代码:根据需要修改代码以适应您的项…

    2025年12月13日
    000
  • pycharm关闭项目很慢怎么解决

    优化 PyCharm 设置、项目设置并解决其他潜在问题可以快速解决 PyCharm 关闭项目速度慢的问题,包括禁用不必要的 File Watcher 和通知、清理缓存和日志、清理项目中的虚拟环境、删除不必要的项目库、清理 Git 缓存、检查防病毒软件、增加系统资源以及重新安装 PyCharm。 Py…

    2025年12月13日
    000
  • pycharm安装要勾选什么

    PyCharm 安装时推荐勾选的选项包括:Python 解释器项目PyCharm 插件项目模板PyCharm 教育版(如果适用) PyCharm 安装时勾选哪些选项 PyCharm 是一款流行的 Python 开发环境,在安装时勾选正确的选项非常重要,以确保获得最合适的安装。 必选选项 Python…

    2025年12月13日
    000
  • pycharm是什么工具

    PyCharm是一种专门用于Python编程的集成开发环境(IDE)。其特点包括:智能代码补全和错误检查功能强大的调试器版本控制集成单元测试支持代码重构代码格式化图形用户界面(GUI)设计器 PyCharm是什么工具? PyCharm是一种用于Python编程的集成开发环境(IDE)。它由JetBr…

    2025年12月13日
    000
  • pycharm可以做什么

    PyCharm 是一款功能强大的 Python 开发环境 (IDE),提供全面的工具和功能,简化 Python 应用程序的开发。其核心功能包括:代码编辑器:语法高亮、自动补全、代码折叠和可自定义配色方案。调试器:交互式调试器,支持断点、单步调试和变量检查。版本控制集成:支持 Git、Mercuria…

    2025年12月13日
    000
  • pycharm如何编程的时候打出中文

    在 PyCharm 中输入中文的方法:启用中文输入法使用 PyCharm 快捷键更改 PyCharm 的键盘布局配置 PyCharm 的语言支持安装中文字体设置代码格式 在 PyCharm 中输入中文 在 PyCharm 中输入中文非常简单,有以下几种方法: 1. 启用中文输入法 Windows:按…

    2025年12月13日
    000
  • pycharm只能运行一个文件怎么办

    解决 PyCharm 只能运行一个文件的问题:激活其他运行配置。禁用调试器。检查文件路径是否正确。取消选中 “Suspend process” 选项。检查外部工具的兼容性。如果以上步骤不起作用,请联系 PyCharm 社区寻求帮助。 解决 PyCharm 只能运行一个文件的问…

    2025年12月13日
    000
  • pycharm社区版怎么配置

    PyCharm 社区版配置指南:安装和配置环境:下载并安装 PyCharm,选择所需的 Python 版本。定制界面:更改主题、字体和工具窗口布局。安装和管理插件:从 PyCharm Marketplace 安装和管理所需的插件。配置调试器:设置断点、启动调试器和检查变量。配置版本控制:将项目添加到…

    2025年12月13日
    000
  • pycharm社区版和专业版界面区别

    PyCharm 社区版和专业版界面差异主要体现在:主工具栏:专业版增加“重构”、“数据库”、“单元测试”等工具。项目视图:专业版提供按层次结构组织项目的“Project View”。编辑器区域:专业版增强代码完成、重构和调试功能。侧边栏:专业版新增“数据库工具”、“单元测试”和“终端”等选项卡。其他…

    2025年12月13日
    000

发表回复

登录后才能评论
关注微信