Patch Cobalt Strike 4.0 Stage X64 Bugs
根据出问题的地方Use x64 payload
,也就是stage x64生成的exe无法正常运行,跟到:
data:image/s3,"s3://crabby-images/345c6/345c654d74a71678e2a429db982345fc685e83f2" alt="-w1532"
boolean bool1 = DialogUtils.bool(this.options, "x64");
如果x64被选择则进入x64生成。
data:image/s3,"s3://crabby-images/6d719/6d7192e51d19478404b5bd0f3367749f9533bb0c" alt="-w1037"
通过代码对比会发现调用的函数都没啥区别。
new ArtifactUtils(this.client).patchArtifact(this.stager, "artifact64.exe", paramString);
跟过来发现两个patchArtifact
的重载方法:
data:image/s3,"s3://crabby-images/e823f/e823f0357fa391eeaffe91e0dff9eef34468e16b" alt="-w827"
data:image/s3,"s3://crabby-images/949f8/949f8184953a47c4bd22554ccadb8e8c3f70ea55" alt="-w886"
可以发现,整个过程中都没有涉及到传递stage
的架构,基本即可以断定和这中间环节没关系了。
继续跟到最终环节:
data:image/s3,"s3://crabby-images/074ea/074ea7229d5161a433dd17a757283192c5bdce9a" alt="-w946"
细节出来了有没有:
this.stager = ListenerUtils.getListener(this.client, str1).getPayloadStager("x86");
明显官方将stage
固定在了x86的,所以把x64的payload写进来自然就不对了。
验证
将86修改为64:
data:image/s3,"s3://crabby-images/3440f/3440f1d275abd839b8aa2c5cdb49f6a6e9e37e26" alt="-w843"
重新打包运行:
data:image/s3,"s3://crabby-images/a910b/a910bdffc5905cb89d1917eae600a1475168f70e" alt="-w399"
data:image/s3,"s3://crabby-images/e13a8/e13a82a544b2a2d9f4322f3a5d1f59a156068568" alt="-w845"
至于完整的代码怎么调整,就自己考虑咯...
data:image/s3,"s3://crabby-images/f444b/f444b45ecfcaba964f15e0b7e3168b60927c131a" alt=""
CoolCat
也无风雨也无晴