首先准备IDEA,激活的话使用
eval reset
,然后是准备CobaltStrike4.3
0x01 反编译Jar文件
使用CFR工具将 ,http://www.benf.org/other/cfr/
java -jar ./cfr-0.151.jar ./cobaltstrike.jar --outputdir ./source
0x02 IDEA创建一个新项目
选择java模板,一路next下去就好
data:image/s3,"s3://crabby-images/3f3f2/3f3f236813d8a3d0b267dd5235a1993056af9c28" alt="notion image"
0x03 创建子目录及添加内容
创建
lib
和decompiled_src
文件夹,把反编译出来的java代码复制到decompiled_src
文件夹中,把cobaltstrike.jar
放到lib
目录下,0x04 设置项目结构
data:image/s3,"s3://crabby-images/570ca/570ca5898ab70fc70a1e56cf44c32583b7d29fd4" alt="notion image"
选择添加jar或者目录,选择lib目录下的jar文件,然后打上✅
data:image/s3,"s3://crabby-images/1538e/1538e535b8ca4f6dda1257275aa004d003d05fb3" alt="notion image"
接着点应用即可添加依赖。然后进入到工件中进行如下操作,其中主类参考lib中的META-INF中的MANIFEST.MF
data:image/s3,"s3://crabby-images/2ec76/2ec769cfe15b1da57cf2f79f9efffa1c7a654b2a" alt="notion image"
data:image/s3,"s3://crabby-images/304c7/304c7ccb3bb6a67cb2885ef5c40ec72fd8c8e500" alt="notion image"
data:image/s3,"s3://crabby-images/6e6a0/6e6a0017205b5f1626bc527e5fca09f79aead42f" alt="notion image"
最终如下所示:
data:image/s3,"s3://crabby-images/38070/380707d69dddecf48cf2dfd61f5c47be436bb0ee" alt="notion image"
0x05 准备重新build项目
在decompiled_src找到aggressor,进行如下操作
data:image/s3,"s3://crabby-images/a9002/a9002f929e7c6cea36bb599d8fb7ba9c5c5537f6" alt="notion image"
复制到src目录下,要保持原路径一样
data:image/s3,"s3://crabby-images/fa4ed/fa4ed32607f434cbc8b5024f5d89a5a064cd313c" alt="notion image"
最终如下所示:
data:image/s3,"s3://crabby-images/724fe/724fed14b50dd73a93313c2d6de6eadaa654f5f9" alt="notion image"
添加测试代码
/*
* Decompiled with CFR 0.151.
*/
package aggressor;
import aggressor.MultiFrame;
import aggressor.dialogs.ConnectDialog;
import aggressor.ui.UseSynthetica;
import common.Authorization;
import common.License;
import common.Requirements;
import sleep.parser.ParserConfig;
import javax.swing.*;
public class Aggressor {
public static final String VERSION = "4.3 (20210317-TW) " + (License.isTrial() ? "Trial" : "Licensed");
public static final String VERSION_SHORT = "4.3";
public static MultiFrame frame = null;
public static MultiFrame getFrame() {
return frame;
}
public static void main(String[] stringArray) {
JOptionPane.showMessageDialog(null,"hello radish");//new add
ParserConfig.installEscapeConstant('c', "\u0003");
ParserConfig.installEscapeConstant('U', "\u001f");
ParserConfig.installEscapeConstant('o', "\u000f");
new UseSynthetica().setup();
Requirements.checkGUI();
License.checkLicenseGUI(new Authorization());
frame = new MultiFrame();
new ConnectDialog(frame).show();
}
}
然后进行build
data:image/s3,"s3://crabby-images/9460a/9460af2fd670231d141124175fb7e84e7fd66715" alt="notion image"
左下角出现成功
data:image/s3,"s3://crabby-images/f0f5c/f0f5cf4609b9941f0ff1c1d0624b2142931074dd" alt="notion image"
会在项目根目录下有一个out文件,新编译的jar包就在里面
data:image/s3,"s3://crabby-images/83a78/83a78c9e480eec8cbaf3542a980183a372009625" alt="notion image"
0x06 Debug客户端
data:image/s3,"s3://crabby-images/47e1d/47e1dbf5b9ccf80eff40a1dc226a900fbb8d7dcf" alt="notion image"
虚拟机选项可以参考cs的启动脚本
start.sh
,在启动debug前把cobaltstrike.auth
复制到新jar的目录下data:image/s3,"s3://crabby-images/965ba/965baec4ba18cfb0c58ce7394d8b7edff19506af" alt="notion image"
尝试打一个断点
data:image/s3,"s3://crabby-images/d999f/d999f01a365ecae59797e22e24a31d6eabe99e4e" alt="notion image"
然后debug运行,首先可以看到我们添加的代码成功运行
data:image/s3,"s3://crabby-images/03e80/03e80917622840696f00f508edd464deb2516ca6" alt="notion image"
接着程序会停在断点上
data:image/s3,"s3://crabby-images/f6bbe/f6bbe9f4d5839504e731c780a22e86f9620cebd5" alt="notion image"
然后f9继续运行程序,会发现程序报错了
data:image/s3,"s3://crabby-images/439ba/439bae3b1f7a117632ab1adbc3565fa6a9048519" alt="notion image"
原因是MANIFEST.MF 没有同步,找到libc目录下META-INF下的MANIFEST.MF,使src下的和它一样就行。
data:image/s3,"s3://crabby-images/a4993/a49938ca77862a9a649c8d19953595430167b76f" alt="notion image"
然后再来一遍debug,客户端成功运行起来
data:image/s3,"s3://crabby-images/5cb16/5cb1659616d81892563bae944b1ae805e4f2e6ff" alt="notion image"
0x07 Debug服务端
通过关键字符串把服务端的入口定位到
server/teamserver
,先把这个文件用同样的方法复制到src目录下,保持目录一样,只复制一个文件,文件多的话,重构时会有大量的语法报错。data:image/s3,"s3://crabby-images/6a024/6a0242586f611e27907ece176391916929266d4a" alt="notion image"
此时的目录结构如下所示
data:image/s3,"s3://crabby-images/e8c02/e8c02d8bb13a5064f6140fcd35557c8d236f5047" alt="notion image"
接着创建一个应用程序的调试配置,虚拟机选项参考teamserver。
data:image/s3,"s3://crabby-images/dfdf0/dfdf04347cd66f31df32a741a2c9c367897589c6" alt="notion image"
VM选项:
-XX:ParallelGCThreads=4 -Dcobaltstrike.server_port=50050 -Dcobaltstrike.server_bindto=0.0.0.0 -Djavax.net.ssl.keyStore=/Users/radish/MyFile/tools/webtools/cobaltstrike4.3/cobaltstrike.store -Djavax.net.ssl.keyStorePassword=123456 -server -XX:+AggressiveHeap -XX:+UseParallelGC
成功断在断点上
data:image/s3,"s3://crabby-images/5f811/5f811df595747be5c25411d53e7c23a3a9204879" alt="notion image"