问答
发起
提问
文章
攻防
活动
Toggle navigation
首页
(current)
问答
商城
实战攻防技术
漏洞分析与复现
NEW
活动
摸鱼办
搜索
登录
注册
冰蝎beta8内存马防查杀破解
冰蝎beta8内存马防查杀破解
今早发现冰蝎webshell 更新至beta8,其中一点更新比较稳,如图 ![图片](https://shs3.b.qianxin.com/butian_public/f680dd6c4c5c8150ae07eb95501d408e8.jpg) 其中新增了内存马防查杀机制,话不多说,盘它。 对比新增的代码,有一点比较突出,如图 ![图片](https://shs3.b.qianxin.com/butian_public/f41561b57c0fa520b1e5d615262a01c4b.jpg) 个人猜想,作者可能是想通过关闭某些pipe,以防止应急响应加载javaagent。正好,我看到很多人都想禁止第三方加载javaagent以保证自己的内存马不被查杀。下面我们来分析一下`sun.tools.attach`都做了什么,为什么无法做到无法禁止javaagent的加载。 要解决上面这个问题,我们需要思考,`sun.tools.attach`是如何于目标JVM通信的,是怎么于目标JMV传递数据的?只有搞清楚这两个问题,我们才能解决怎样禁止javaagent加载 > 以下分析基于windows 1. java层 -------- 我们先从最基础的,向一个正在运行的JVM加载agent的操作开始分析。很多恶意javaagent,都在想方设法禁止后续javaagent加载 ```php List<VirtualMachineDescriptor> vms = VirtualMachine.list(); for(VirtualMachineDescriptor vm:vms){ if (vm.displayName().contains("catalina")){ VirtualMachine v = VirtualMachine.attach(vm); v.loadAgent("D:\\sources\\AgentMemShellScanner\\tools_0.jar", "L2E=|L2E="); } } ``` 其实调用的是如下代码 ![图片](https://shs3.b.qianxin.com/butian_public/f8b4fb6efd2a79c477bf4a316d620dfc1.jpg) ![图片](https://shs3.b.qianxin.com/butian_public/f706deb1404457bafcbf4ff4ab71ebb04.jpg) 上面的操作其实就是打开目标JVM的进程。`loadagent`方法的代码如下 ![图片](https://shs3.b.qianxin.com/butian_public/f605b1cdabd3e63991a4e24021cdd1856.jpg) 最终其实调用的是 ![图片](https://shs3.b.qianxin.com/butian_public/f6d02217848e5fdb683ff1eee08333fd8.jpg) 加载agent这个操作,首先打开目标进程JVM,然后再创建一个pipe,后缀数字为随机数。然后再通过某些操作,执行命令。上图中大多数函数都为JNI函数,我们接着分析 2. JNI 部分 --------- openprocess这个函数就不过多详细介绍了,只是调用windows api打开进程,如图 ![图片](https://shs3.b.qianxin.com/butian_public/f863630114bd5b224cf2b6830b2938e22.jpg) 我们知道,在windows 进程ipc通信中,如果两个进程需要使用Pipe通信,则通信双方都需要打开pipe。而在这里,我们的java创建了Pipe,但是目标JVM并不知道我们的pipe名称。如果不知道名称就无法做IPC通信。下面分析一下怎么通知目标JVM需要读取pipe数据的。 在java中,首先创建Pipe,然后通过`enqueue`方法,同过管道向目标JVM写入命令。在`enqueue`的JNI方法中,我们看到了如下的代码 ![图片](https://shs3.b.qianxin.com/butian_public/ff95b65af6e4e1b1fd5422d83e1d99f57.jpg) 典型的shellcode注入代码,向目标内存申请内存,类型为可读可写可执行,然后复制shellcode到刚才申请的内存中,然后通过CreateRemoteThread调用shellcode。当然,这段shellcode可不是什么而已操作,只是完成某些JVM指令。 这段shellcode是通过`generateStub`函数生成,同样也是一个native函数。分析一下`generateStub` ![图片](https://shs3.b.qianxin.com/butian_public/f717a356d0bbefd63f5ced2ce900d62e7.jpg) 很明显,这段shellcode的内容,其实为`jvm_attach_thread_func`的内容。当然,在这里就不详细介绍了,学一些简单的c就能看懂上面的代码。 ![图片](https://shs3.b.qianxin.com/butian_public/f6e4f3dbd1f39b3ce6080ba6754b7e35f.jpg) 简单概括,就是我们的java进程,通过向目标JVM注入shellcode来执行我们与目标JVM的通信指令。Pipe只是一种通信手段,关闭pipe并不能影响我们向目标JVM加载javaagent。 当然,目标JVM都做了什么操作,在这里就不分析了。 回到最初疑问,我们通过分析可以得出以下结论: > 要想禁止javaagent加载,首先需要禁止目标JVM进程被打开或者禁止向目标JVM注入shellcode。JVM可能无法完成禁止javaagent加载这个操作。但这是不是给了某些edr产品的防护javaagent内存马的思路?? 至于冰蝎的内存马,看样子依旧可以正常查杀,毫不影响。 不过,我看到内存马中多了另外一种JVM持久化方法,正好前段时间研究过。兄弟们转发支持,多多加入星球。明后天更新基于Classpath的jvm持久化方法。 **文章转载于"宽字节安全"公众号,已取得转载授权。**
发表于 2021-05-27 18:14:35
阅读 ( 6506 )
分类:
WEB安全
0 推荐
收藏
0 条评论
请先
登录
后评论
带头大哥
50 篇文章
×
发送私信
请先
登录
后发送私信
×
举报此文章
垃圾广告信息:
广告、推广、测试等内容
违规内容:
色情、暴力、血腥、敏感信息等内容
不友善内容:
人身攻击、挑衅辱骂、恶意行为
其他原因:
请补充说明
举报原因:
×
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!