热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Faxhell:一个利用Fax服务和DLL劫持技术实现的BindShell

FaxhellFaxhell,又名“FaxShell”,它是一个利用利用Fax服务和DLL劫持技术实现的BindShell,Faxhell本身就是一个针对BindShell的概念验



Faxhell


Faxhell,又名“Fax Shell”,它是一个利用利用Fax服务和DLL劫持技术实现的Bind Shell,Faxhell本身就是一个针对Bind Shell的概念验证PoC,其中的DLL劫持基于Ualapi.dll实现。


如何使用


首先,我们需要构建Ualapi.dll文件,并将其存放至“c:\windows\system32”路径下。接下来,开启系统的Fax服务,该服务启动后将会加载我们的DLL文件,并调用“UalStart”导出函数。


此时,“UalStart”会将线程池内的工作项加入一个队列之中,并开启一个针对“RpcSs”的控制器,然后寻找一个SYSTEM令牌。找到之后,代码便会复制其内容并伪装成该令牌。


接下来,它将会使用本地终端地址创建一个socket会话,并将其绑定至端口9299,然后使用线程池的IO Completion端口异步等待传入的链接。


配置好上述内容之后,我们需要使用熟悉的客户端(例如nc(at).exe 9299)来连接绑定端口9299的socket会话。然后输入“let me in”并按下回车键。如果你编写了自定义代码,可以尝试发送字符串“let me in\n”。


I/O Completion包将会唤醒线程池回调,而回调请求将会开启Cmd.exe进程,并使用SYSTEM权限运行DcomLaunch服务。此时,就会将其输入和输出处理器绑定到新创建的socket会话上了。


终端防护响应/反病毒绕过



  • 使用一个不常见或很少人知道的服务,或者使用EDR厂商不会监控或标记为“可疑”的服务。

  • 使用Windows线程池API来配置,增加栈内存的读取难度,通过多个线程来均衡工作负载,避免出现可疑情况的提示。

  • 伪造令牌的有效期非常短,必须让工作线程以SYSTEM权限运行,只有在每次API调用完成之后,才恢复网络服务,这样可以降低被扫描器捕捉到的机率。

  • 使用不常见的socket API,让导入的表没有那么可疑,并躲避EDR检测、LOCTL钩子和LSP。

  • 在DcomLaunch服务下创建Bind Shell,这个服务已经是一个拥有SYSTEM权限的服务了,因此我们的行为看起来会更加自然,避免出现可疑的进程树。

  • 利用Windows漏洞,让socket看起来属于Fax服务,而并非EcomLaunch或exe。如果我们终止Fax服务,那么socket将会属于System。



注意事项


根据前文的介绍,想必大家应该已经了解了Faxhell的工作机制和使用方法了。但是,这并不意味着Faxhell是一个可以直接丢进目标系统执行,并且无法被检测和察觉的恶意攻击武器。


首先,Faxhell只是一个Bind Shell,大多数防火墙都可以阻止其活动。打开防火墙规则,或使用一个反向Bind Shell,或者使用类似80和443这样的常见端口来实现数据通信会更加有效。


其次,比如说Spooler这样的常见服务同样也能够加载我们的Ualapi.dll。


第三,我们提供的这个Faxhell PoC可能会造成内存泄漏。


参考文档


1、 https://windows-internals.com/faxing-your-way-to-system/


项目地址


Faxhell:【 GitHub传送门




推荐阅读
  • 调试利器SSH隧道
    在开发微信公众号或小程序的时候,由于微信平台规则的限制,部分接口需要通过线上域名才能正常访问。但我们一般都会在本地开发,因为这能快速的看到 ... [详细]
  • 本文将从基础概念入手,详细探讨SpringMVC框架中DispatcherServlet如何通过HandlerMapping进行请求分发,以及其背后的源码实现细节。 ... [详细]
  • 本文详细介绍了Sleep函数的基本概念、使用方法及其背后的实现原理。适合对Sleep函数的使用和实现感兴趣的开发者阅读。通过本文,您将了解如何在不同操作系统中使用Sleep函数,以及其在多线程编程中的重要性。 ... [详细]
  • 关于进程的复习:#管道#数据的共享Managerdictlist#进程池#cpu个数1#retmap(func,iterable)#异步自带close和join#所有 ... [详细]
  • 本文整理了一份基础的嵌入式Linux工程师笔试题,涵盖填空题、编程题和简答题,旨在帮助考生更好地准备考试。 ... [详细]
  • 在测试软件或进行系统维护时,有时会遇到电脑蓝屏的情况,即便使用了沙盒环境也无法完全避免。本文将详细介绍常见的蓝屏错误代码及其解决方案,帮助用户快速定位并解决问题。 ... [详细]
  • 为何Compose与Swarm之后仍有Kubernetes的诞生?
    探讨在已有Compose和Swarm的情况下,Kubernetes是如何以其独特的设计理念和技术优势脱颖而出,成为容器编排领域的领航者。 ... [详细]
  • Requests库的基本使用方法
    本文介绍了Python中Requests库的基础用法,包括如何安装、GET和POST请求的实现、如何处理Cookies和Headers,以及如何解析JSON响应。相比urllib库,Requests库提供了更为简洁高效的接口来处理HTTP请求。 ... [详细]
  • 【小白学习C++ 教程】二十三、如何安装和使用 C++ 标准库
    【小白学习C++ 教程】二十三、如何安装和使用 C++ 标准库 ... [详细]
  • 本文介绍了如何利用X_CORBA实现远程对象调用,并通过多个示例程序展示了其功能与应用,包括基础的Hello World示例、文件传输工具以及一个完整的聊天系统。 ... [详细]
  • 本文详细介绍了进程、线程和协程的概念及其之间的区别与联系。进程是在内存中运行的独立实体,具有独立的地址空间和资源;线程是操作系统调度的基本单位,属于进程内部;协程则是用户态下的轻量级调度单元,性能更高。 ... [详细]
  • RTThread线程间通信
    线程中通信在裸机编程中,经常会使用全局变量进行功能间的通信,如某些功能可能由于一些操作而改变全局变量的值,另一个功能对此全局变量进行读取& ... [详细]
  • 大华股份2013届校园招聘软件算法类试题D卷
    一、填空题(共17题,每题3分,总共51分)1.设有inta5,*b,**c,执行语句c&b,b&a后,**c的值为________答:5 ... [详细]
  • RocketMQ 运维监控实践指南
    本文详细介绍了如何实现 RocketMQ 的运维监控,包括监控平台的搭建、常用运维命令及其具体用法。适合对 RocketMQ 监控感兴趣的读者参考。 ... [详细]
  • 普通树(每个节点可以有任意数量的子节点)级序遍历 ... [详细]
author-avatar
fuzhipai
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有