后门[说明]清除DLL后门木马方法秘诀

木马后门  时间:2021-04-07  阅读:()

清除DLL后门木马方法秘诀

后门相信这个词语对您来说一定不会陌生它的危害不然而欲但随着人们的安全意识逐步增强又加上杀毒软件的"大力支持"使传统的后门无法在隐藏自己任何稍微有点计算机知识的人都知道"查端口""看进程" 以便发现一些"蛛丝马迹"。所以后门的编写者及时调整了思路把目光放到了动态链接程序库上也就是说把后门做成DLL文件然后由某一个EXE做为载体或者使用Rundll32.exe来启动这样就不会有进程不开端口等特点也就实现了进程、端口的隐藏。本文以"DLL的原理""DLL的清除""DLL的防范"为主题并展开论述 旨在能让大家对DLL后门"快速上手"不再恐惧DLL后门。好了进入我们的主题。

一 DLL的原理

1动态链接程序库

动态链接程序库全称 Dynamic Link Library简称 DLL作用在于为应用程序提供扩展功能。应用程序想要调用DLL文件需要跟其进行"动态链接"从编程的角度应用程序需要知道DLL文件导出的AP I函数方可调用。 由此可见 D LL文件本身并不可以运行需要应用程序调用。正因为DLL文件运行时必须插入到应用程序的内存模块当中这就说明了 DLL文件无法删除。这是由于Windows内部机制造成的正在运行的程序不能关闭。所以 DLL后门由此而生

2 DLL后门原理及特点

把一个实现了后门功能的代码写成一个DLL文件然后插入到一个EXE文件当中使其可以执行这样就不需要占用进程也就没有相对应的PID号也就可以在任务管理器中隐藏。 DLL文件本身和EXE文件相差不大但必须使用程序EXE调用才能执行DLL文件。 DLL

文件的执行需要EXE文件加载但EXE想要加载DLL文件需要知道一个DLL文件的入口函数既DLL文件的导出函数 所以根据DLL文件的编写标准 EXE必须执行DLL文件中的DLLMai n  作为加载的条件如同EXE的mi an    。做DLL后门基本分为两种 1把所有功能都在DLL文件中实现 2把DLL做成一个启动文件在需要的时候启动一个普通的EXE后门。

常见的编写方法

(1) 只有一个DLL文件

这类后门很简单只把自己做成一个DLL文件在注册表Run键值或其他可以被系统自动加载的地方使用Rundl l32.exe来自动启动。Rundll32.exe是什么顾名思意 "执行32位的DLL文件"。它的作用是执行DLL文件中的内部函数这样在进程当中只会有

Rundll32.exe而不会有DLL后门的进程这样就实现了进程上的隐藏。如果看到系统中有多个Rundll32. exe不必惊慌这证明用Rundll32.exe启动了多少个的DLL文件。当然这些Rundll32.exe执行的DLL文件是什么我们都可以从系统自动加载的地方找到。

现在我来介绍一下Rundll 32. exe这个文件意思上边已经说过功能就是以命令行的方式调用动态链接程序库。系统中还有一个Rundll. exe文件他的意思是"执行16位的DLL文件"这里要注意一下。在来看看Rundll 32. exe使用的函数原型

Void CALLBACK Funct ionName (

HWND hwnd,

HINSTANCE hinst,

LPTSTR lpCmdLine,

Int nCmdShow

) ;

其命令行下的使用方法为 Rundl l32.exe DLLname,Functionname[Argument s]

DLLname为需要执行的DLL文件名Func t ionname为前边需要执行的DLL文件的具体引出函数 [Argument s]为引出函数的具体参数。

(2) 替换系统中的DLL文件

这类后门就比上边的先进了一些它把实现了后门功能的代码做成一个和系统匹配的DLL文件并把原来的DLL文件改名。遇到应用程序请求原来的DLL文件时 DLL后门就启一个转发的作用把"参数"传递给原来的DLL文件如果遇到特殊的请求时比如客户端 DLL后门就开始启动并运行了。对于这类后门把所有操作都在DLL文件中实现最为安全但需要的编程知识也非常多也非常不容易编写。所以这类后门一般都是把DLL文件做成一个"启动"文件在遇到特殊的情况下比如客户端的请求 就启动一个普通的EXE后门在客户端结束连接之后把EXE后门停止然后DLL文件进入"休息"状态在下次客户端连接之前都不会启动。但随着微软的"数字签名"和"文件恢复"的功能出台这种后门已经逐步衰落。

提示

在WINNT\system32 目录下有一个dllcache文件夹里边存放着众多DLL文件也包括一些重要的EXE文件 在DLL文件被非法修改之后系统就从这里来恢复被修改的DLL文件。如果要修改某个DLL文件首先应该把dll cache目录下的同名DLL文件删除或更名否则系统会自动恢复。

(3) 动态嵌入式

这才是DLL后门最常用的方法。其意义是将DLL文件嵌入到正在运行的系统进程当中。在Windows系统中每个进程都有自己的私有内存空间但还是有种种方法来进入其进程的私有内存空间来实现动态嵌入式。由于系统的关键进程是不能终止的所以这类后门非常隐蔽查杀也非常困难。常见的动态嵌入式有 "挂接API""全局钩子

HOOK ""远程线程"等。

远程线程技术指的是通过在一个进程中创建远程线程的方法来进入那个进程的内存地址空间。当EXE载体或Rundll32. exe在那个被插入的进程里创建了远程线程并命令它执行某个DLL文件时我们的DLL后门就挂上去执行了这里不会产生新的进程要想让DLL后门停止只有让这个链接DLL后门的进程终止。但如果和某些系统的关键进程链接那就不能终止了如果你终止了系统进程那Windows也随即被终止  

3 DLL后门的启动特性

启动DLL后门的载体EXE是不可缺少的也是非常重要的它被称为 Loader。如果没有Loader那我们的DLL后门如何启动呢因此一个好的DLL后门会尽力保护自己的Loader不被查杀。 Loader的方式有很多可以是为我们的DLL后门而专门编写的一个EXE文件也可以是系统自带的Rundl l32.exe即使停止了Rundll32. exe DLL后门的主体还是存在的。 3721网络实名就是一个例子虽然它并不是"真正"的后门。

二 DLL的清除

本节以三款比较有名的DLL后门例分别为

"SvchostDLL.dll""BITS.dll""QoServer.dll"。详细讲解其手工清除方法。希望大家在看过这三款DLL后门的清除方法之后能够举一反

三灵活运用在不惧怕DLL后门。其实手工清除DLL后门还是比较简单的无非就是在注册表中做文章。具体怎么做请看下文。

1 PortLess BackDoor

这是一款功能非常强大的DLL后门程序除了可以获得LocalSystem权限的Shell之外还支持如"检测克隆帐户""安装终端服务"等一系列功能具体可以参见程序帮助适用Windows2000/xp/2003等系统。程序使用svchost.exe来启动平常不开端口可以进行反向连接最大的特点哦 对于有防火墙的主机来说这个功能在好不过了。

在介绍清除方法之前我们先来简单的介绍一下svchost.exe这个系统的关键服务

Svchost只是做为服务的宿主本身并不实现什么功能如果需要使用Svchost来启动服务则某个服务是以DLL形式实现的该DLL的

载体Loader指向svchost所以在启动服务的时候由svchost调用该服务的DLL来实现启动的目的。使用svchost启动某个服务的DLL文件是由注册表中的参数来决定的在需要启动服务的下边都有一个Parameters子键其中的Servi ceDll表明该服务由哪个DLL文件负责并且这个DLL文件必须导出一个ServiceMain()函数为处理服务任务提供支持。

呵呵看了上边的理论是不是有点蒙我都快睡着了 别着急我们来看看具体的内容。首先我们看一下注册表

HKEY_LOCAL_MACHINE\SYSTEM\CurrentContro lSet\Serv ice s\RpcS s下的Parameters子键其键值

为%SystemRoot%\system32\rpcss.dll。这就说明启动RpcSs服务时。 Svchost调用WINNT\system32目录下的rpcss.dll。

再看看另一个例子在注册表的

HKEY_LOCAL_MACHI NE\SOFTWARE\Mi cros of t\W indows

NT\CurrentVersion\Svchost里边存放着Svchost启动的组和组内的各个服务其中netsvcs组的服务最多。要使用Svchost启动某个服务则该服务名就会出现在

HKEY_LOCAL_MACHI NE\SOFTWARE\Mi cros of t\W indows

NT\CurrentVersion\Svchost下。这里有四种方法来实现

1 添加一个新的组在组里添加服务名

2 在现有组里添加服务名

3 直接使用现有组里的一个服务名但是本机没有安装的服务

4 修改现有组里的现有服务把它的ServiceDll指向自己的DLL后门

我测试的PortLess BackDoor使用的第三种方法。

好了我想大家看完了上边的原理一定可以想到我们清除PortLessBackDoor的方法了对就是在注册表的Svchost键下做文章。好我们现在开始。

后门的Loader把SvchostDLL.dll插入Svchost进程当中所以我们先打开Windows优化大师中的Windows进程管理2.5查看Svchost进程中的模块信息可以看到 SvchostDLL.dll已经插入到Svchost进程中了在根据"直接使用现有组里的一个服务名但是本机没有安装的服务"的提示我们可以断定在"管理工具"—"服务"中会有一项新的服务。通过查看可以证明此服务名称为 IPRIP由Svchost启动 -k netsvcs表示此服务包含在netsvcs服务组中。

我们把该服务停掉然后打开注册表编辑器开始—运行

--regedit 来到

HKEY_LOCAL_MACHINE\SYSTEM\CurrentContro lSet\Serv ices\IPRIP下查看其Parameters子键。 Program键的键值SvcHostDLL.exe为后门的Loader ServiceDll的键值

C:\WINNT\system32\svchostdll.dll为调用的DLL文件这正是后门的DLL文件。现在我们删除IPRIP子键或者用SC来删除 然后在来到HKEY_LOCAL_MACH INE\SOFTWARE\M i cr o so f t\Wi n dow sNT\CurrentVersion\Svchost下编辑netsvcs服务组把49 00 7000 72 00 69 00 70 00 00 00删除这里对应的就是IPRIP的服务名。然后退出重启。重启之后删除WINNT\system32 目录下的后门文件即可。

2 BITS.dll

这是榕哥的作品也是DLL后门和SvchostDLL.dll原理基本一样不过这里使用的是上边介绍的第四种方法 即"修改现有组里的现有服务把它的ServiceDll指向自己的DLL后门"。换句话说该后门修改现有的某一个服务把其原有服务的DLL指向自己也就是BITS.dll 这样就达到了自动加载的目的其次该后门没有自己的Loader而是使用系统自带的Rundll32.exe来加载。我们还是用Windows进程管理2.5来查看我们可以看到bits.dll已经插入到Svchost进程当中。

好现在我们来看看具体的清除方法 由于该后门是修改现有服务而我们并不知道具体是修改了哪个服务所以在注册表中搜索bits.dll最后在

HKEY_LOCAL_MACHINE\SYSTEM\CurrentContro lSet\Serv ices\RasAuto下搜索到了bits.dll查看Parameters子键下的ServiceDll其键值为C:\WINNT\system32\bits.dll。原来该后门把RasAuto服务原来的DLL文件替换为bits.dll了这样来实现自动加载。知道了原因就好办了现在我们把ServiceDl l的键值修改为RasAuto服务原有的DLL文件即%SystemRoot%\System32\rasauto.dl l退出重启。之后删除WINNT\system32 目录下的bits. dll即可。

3 NOIR--QUEEN

NO IR--QUEEN(守护者)是一个DLL后门&木马程序服务端以DLL文件的形式插入到系统的Lsass. exe进程里由于Lsass.exe是系统的关键进程所以不能终止。在来介绍清除方法之前我先介绍一下Lsass.exe进程

这是一个本地的安全授权服务并且它会为使用Winlogon服务的授权用户生成一个进程如果授权是成功的 Lsass就会产生用户的进

入令牌令牌使用启动初始的Shell。其他的由用户初始化的进程会继承这个令牌。

从上边的介绍我们就可以看出Lsass对系统的重要性那具体怎么清除呢请看下文。

后门在安装成功后会在服务中添加一个名为QoSserver的服务并把QoSserver.dll后门文件插入到Lsass进程当中使其可以隐藏进程并自动启动。现在我们打开注册表来到

HKEY_LOCAL_MACHINE\SYSTEM\CurrentContro lSet\Serv ices\QoSserver直接删除QoSserver键然后重启。重启之后我们在来到服务列表中会看到QoSserver服务还在但没有启动类别是自动我们把他修改为"已禁用"然后往上看会发现一个服务名为AppCPI的服务其可执行程序指向QoSserver.exe 原因后边我会说到 具体如图11所示。我们再次打开注册表来到

HKEY_LOCAL_MACHINE\SYSTEM\CurrentContro lSet\Serv ice s\AppCPI删除AppCPI键重启再删除QoSserver最后删除WINNT\system32目录下的后门文件。

本人和这个后门"搏斗"了3个多小时重启N次。原因在于即使删除了QoSserver服务后门还是在运行而且服务列表中的QoSserver服务又"死灰复燃"。后来才知道原因在我删除了QoSserver服务并重启之后插入到Lsass进程当中的QoSserver.dll文件又恢复了QoSserver服务并且生成了另外一个服务即AppCPI所以我们必须在到注册表中删除AppCPI服务才算是把该后门清除。由此可以看出现在的后门的保护措施真是一环扣环。

注意在删除QoSserver服务并重启之后恢复的QoSserver的启动类别要修改为"已禁用"否则即便删除了AppCPI服务 QoSserver服务又运行了。

轻云互联(19元)香港高防云服务器 ,美国云服务器

轻云互联成立于2018年的国人商家,广州轻云互联网络科技有限公司旗下品牌,主要从事VPS、虚拟主机等云计算产品业务,适合建站、新手上车的值得选择,香港三网直连(电信CN2GIA联通移动CN2直连);美国圣何塞(回程三网CN2GIA)线路,所有产品均采用KVM虚拟技术架构,高效售后保障,稳定多年,高性能可用,网络优质,为您的业务保驾护航。活动规则:用户购买任意全区域云服务器月付以上享受免费更换IP服...

CloudCone:洛杉矶MC机房KVM月付1.99美元起,支持支付宝/PayPal

CloudCone是一家成立于2017年的国外VPS主机商,提供独立服务器租用和VPS主机,其中VPS基于KVM架构,多个不同系列,譬如常规VPS、大硬盘VPS等等,数据中心在洛杉矶MC机房。商家2021年Flash Sale活动继续,最低每月1.99美元,支持7天退款到账户,支持使用PayPal或者支付宝付款,先充值后下单的方式。下面列出几款VPS主机配置信息。CPU:1core内存:768MB...

妮妮云80元/月,香港站群云服务器 1核1G

妮妮云的来历妮妮云是 789 陈总 张总 三方共同投资建立的网站 本着“良心 便宜 稳定”的初衷 为小白用户避免被坑妮妮云的市场定位妮妮云主要代理市场稳定速度的云服务器产品,避免新手购买云服务器的时候众多商家不知道如何选择,妮妮云就帮你选择好了产品,无需承担购买风险,不用担心出现被跑路 被诈骗的情况。妮妮云的售后保证妮妮云退款 通过于合作商的友好协商,云服务器提供2天内全额退款,超过2天不退款 物...

木马后门为你推荐
experiencedtoyw372:ComIE主页被修改为http://www.hao372.com/ 桌面上的IE图标还变成了两个企业邮局系统企业邮件系统用什么软件好?sns平台什么是SNS?企业cmscms系统的概念是什么filezillaserverFileZilla Server 搭建的FTP服务器波音737起飞爆胎一般的客机的起飞速度是多少?asp.net网页制作开发ASP.NET的网站,步骤是怎样?有经验的可以说说自己的经验支付宝注册网站在哪里注册支付宝三友网有了解唐山三友集团的吗?大学生待遇如何,工资收入,福利保障,工作环境等等
虚拟主机试用30天 主机点评 l5639 香港机房托管 外国域名 12306抢票助手 国内php空间 合肥鹏博士 河南m值兑换 服务器监测 东莞服务器 优酷黄金会员账号共享 raid10 photobucket 创速 带宽测试 锐速 香港ip japanese50m咸熟 美国主机侦探 更多