使用 Visual Studio 开发 CS 的 BOF

简介: 使用 Visual Studio 开发 CS 的 BOF

0x00 前言

   关于BOF大家应该不太陌生了,由CobaltStrike 4.1引入的功能被大家熟知,介绍:聊聊Cobalt Strike 4.1的 BOF

   说白了也就是程序编译后还没有链接的中间产物,在红队行动中,一般由我们的植入体充当链接器,这样一来我们编写的obj文件体积又小且不落地,十分不错,也可以算是OPSEC的方式。

0x01 Visual-Studio-BOF-template优化

   开发BOF可能大家会用到,https://github.com/dtmsecurity/bof_helper这个工具

   再者就是Trustedsec提供的模板,https://github.com/trustedsec/CS-Situational-Awareness-BOF

   或是https://github.com/securifybv/Visual-Studio-BOF-template

   后者的项目可以添加一个Visual Studio的项目模板,其中定义了一些用作BOF动态解析的函数,以及对这些函数结构又做了一次宏定义。

   这样的话我们预先定义好就不用再代码中将用到的API都按KERNEL32$HeapAlloc类似这样的格式编写了;最后还可以BOF和平常c的编译格式切换:

   这样最大的好处就是调试和编译BOF变得十分方便,而且是在我们比较熟悉的Visual Studio上面。

Visual-Studio-BOF-template项目中提供的bofdef.h文件是比较旧的,于是乎我将trustedsec这两个项目中的bofdef.h文件更换到了模板中,又进行了分类,这样定义编写都比较方便明了:

按导出DLL名字区分文件,如果其中缺少定义还可以自己添加

添加函数结构定义后,回到bofdef.h文件添加对应的宏定义

   最后就可以像写C代码一样编写BOF了。

   比如COM添加计划任务的例子,定义好需要的结构后,不用担心任何规定语法直接像写C一样编写:

0x03 添加模板

git clone https://github.com/evilashz/Visual-Studio-BOF-template

   模板我更改为Visual Studio 2022 工具集VS143,当然如果你没有的话也不妨碍,创建项目后再属性设置工具集即可。

路径为

%UserProfile%\Documents\Visual Studio 2022\Templates\ProjectTemplates

将模板文件夹放入即可,创建项目时即可看到,

0x04 总结

   总而言之,说白了,我是十分推荐用这个项目去做BOF开发的,编译和调试非常方便,理论上定义好各类的函数,就可以做到直接将现有的C代码复制过来就可以编译一个BOF。

   所以说我写这篇文章的意思就是希望大家一起使用这个项目,将平时自己编写添加的函数结构都可以集合到bofdef中,欢迎大家PR。

相关文章
|
6月前
Visual Studio Code开发常用的工具栏选项,查看源码技巧以及【vscode常用的快捷键】
Visual Studio Code开发常用的工具栏选项,查看源码技巧以及【vscode常用的快捷键】
260 0
|
7月前
|
开发框架 .NET 数据库
asp.net企业费用报销管理信息系统VS开发sqlserver数据库web结构c#编程Microsoft Visual Studio
asp.net 企业费用报销管理信息系统是一套完善的web设计管理系统,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。开发环境为vs2010,数据库为sqlserver2008,使 用c#语言开发 应用技术:asp.net c#+sqlserver 开发工具:vs2010 +sqlserver
52 0
|
7月前
|
Java Android开发 C++
[笔记]Visual Studio 2015 开发安卓so库JNI层——回调调用
[笔记]Visual Studio 2015 开发安卓so库JNI层——回调调用
|
7月前
|
移动开发 Java 开发工具
[笔记]Visual Studio 2015 开发安卓so库JNI层——HelloWorld
[笔记]Visual Studio 2015 开发安卓so库JNI层——HelloWorld
|
7月前
|
存储 缓存 JSON
用 Visual Studio Code 开发 Angular 应用自动生成的 .angular 文件夹
用 Visual Studio Code 开发 Angular 应用自动生成的 .angular 文件夹
32 0
|
8月前
|
前端开发 JavaScript PHP
Visual Studio Code的使用心得与常用免费插件使用技巧大全总结 老板夸奖我是开发小能手!
这就是我一直在使用的免费代码编辑神器, 它的优点太多了, 有: 智能感知、代码调试、内置 Git 命令、可扩展和可定制都相当牛,最关键的是免费开源!!
215 3
Visual Studio Code的使用心得与常用免费插件使用技巧大全总结 老板夸奖我是开发小能手!
|
8月前
|
数据可视化 C# 开发者
开发小技巧 - 合理使用Visual Studio 2022内置任务列表(TODO)
开发小技巧 - 合理使用Visual Studio 2022内置任务列表(TODO)
|
9月前
|
C语言 C++ Python
【ROS 开发神器 Visual Studio Code 的安装和设置】
【ROS 开发神器 Visual Studio Code 的安装和设置】
343 0
【ROS 开发神器 Visual Studio Code 的安装和设置】
|
12月前
|
IDE 编译器 开发工具
教你如何使用 Visual Studio IDE 正确的进行 C++ 桌面开发
教你如何使用 Visual Studio IDE 正确的进行 C++ 桌面开发
|
开发工具 虚拟化 C++
驱动开发:配置Visual Studio驱动开发环境
在正式开始驱动开发之前,需要自行搭建驱动开发的必要环境,首先我们需要安装`Visual Studio 2013`这款功能强大的程序开发工具,在课件内请双击`ISO`文件并运行内部的`vs_ultimate.exe`安装包,`Visual Studio`的安装非常的简单,您只需要按照提示全部选择默认参数即可,根据机器配置不同可能需要等待一段时间;
1485 0
驱动开发:配置Visual Studio驱动开发环境