ホームページ > php教程 > php手册 > 単一の Index.php は、任意のレベルでの PHP フォルダー トラバーサルを実装します (Zjmainstay によるオリジナル)

単一の Index.php は、任意のレベルでの PHP フォルダー トラバーサルを実装します (Zjmainstay によるオリジナル)

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2016-06-13 11:59:03
オリジナル
1445 人が閲覧しました

以下是核心文件:
index.php文件

复制代码 代码如下:


header('Content-Type:text/html charset:utf-8');
date_default_timezone_set('PRC');
$rootDir = 'listFile'; //站点根目录,装载本程序所有文件
//站点base_url设置方法:
//考虑到通用性,现默认使用方法二,修改方法时注意同时修改.htaccess文件
//方法一:设置站点目录为根目录
//对应.htaccess:
//#RewriteBase /
// $base_url = 'http://www.listfile.com/';
//方法二:设置站点子目录为根目录
//对应.htaccess:
//RewriteBase /listFile/
$base_url = 'http://www.test.com/' .$rootDir .'/';
//解析文件夹路径
if(empty($_GET['return'])){
$dir = '.';
}else {
$dir = trim(array_pop(explode($rootDir,$_GET['return'])),'/');
if(empty($dir)) $dir = '.';
else $dir = './' . $dir;
}
// echo $dir; //当前文件夹
//遍历当前文件夹
$pattern = '*'; // '*'搜索全部文件,可以智能匹配,如*.jpg 搜索jpg文件,*.{jpg,png}搜索jpg和png文件,区分大小写!!
$skip = '*.skip'; //排除.skip类型文件(对应了“被跳过输出文件.skip”),你可以自己修改,如*.php排除所有php文件
$files = scandir_through($dir,$pattern,$skip,false);
?>



List Files








//文件类型数组
$filetypes = array(
'txt' => 'txt文本文件',
'dir' => '文件夹',
'php' => 'php文件',
'css' => 'css文件',
'js' => 'js文件',
'doc' => 'Word文档',
'xls' => 'Excel工作表',
'jpg' => 'jpg图片文件',
'gif' => 'gif图片文件',
'png' => 'png图片文件',
'mp3' => 'mp3文件',
'zip' => 'zip压缩包',
'rar' => 'rar压缩包',
'htm' => 'htm网页文件',
'html' => 'html网页文件',
'undefined'=>'文件类型未知',
);
//自定义屏蔽输出文件
$skipfiles = array(
'index.php',
'index.html',
'jquery-1.6.2.min.js',
'main.js',
'base.css',
);
//按规律输出当前文件夹所有文件
echo "

";
echo "
";
echo "
名称
大小
";
echo "
类型
修改日期
";
foreach($files['filename'] as $index => $file){
if(in_array($file,$skipfiles)) continue;
if(is_null($filetypes[$files['ext'][$index]])) $filetype = '文件类型未知';
else $filetype = $filetypes[$files['ext'][$index]];
echo "
";
echo "
{$files['filesize'][$index]} 
{$filetype}
";
echo "
{$files['filemtime'][$index]}
";
}
echo '
';

//フォルダー トラバーサル関数
function scandir_through($dir,$pattern='*',$skip=false,$subInclude=true,$flag=GLOB_BRACE){
$files = array()
// 現在のディレクトリを取得します。
$items = glob($dir . '/*');
//すべてのアイテムを走査し、$subInclude が true に設定されている場合、サブディレクトリ
を走査し続けます ($ i = 0; $i < count($items); $i ) {
if ($subInclude && is_dir($items[$i])) {
$add = glob($items[$i ] . '/*');
if($add === false) $add = array();
$items, $add); $slash = strrpos($items[$i],'/');
$dir = substr($items[$i],0,$slash);
//現在のファイルがファイルと一致する場合パターン $pattern を検索し、$files 配列に追加します。
if(in_array($items[$i],glob($dir.'/'.$pattern,$flag)) && (($skip==) =false) || !in_array($items[$i],glob($dir.'/'.$skip,$flag)))) {
$files['filemtime'][] = date(' Y-m-d H: i:s',filemtime($items[$i])); //iconv
$items[$i] = の後に中国語名のファイルの時刻が取得できない問題を解決するためにここに置きます。 iconv('gb2312','utf- 8',$items[$i]);
$file = substr($items[$i],$slash 1); [] = $items[$i] ;
$files['filename'][] = $file;
if(is_dir($items[$i])) {
$files['ext] '][] = 'dir';
$files['filesize'][] = '';
}else {
$files['filesize'][] = ceil(filesize($file) )/1024).'KB';
if(strrpos($file,'.') === false) $files['ext'][] = '未定義';
else $files[' ext'][] = strto lower(array_pop (explode('.',$file)));
}
}
}
return $files; 🎜>/*
// .htaccess ファイルはルート ディレクトリにあります。 原則: アクセス パスはファイル、つまりフォルダーではないため、分析のためにルート パスにジャンプします。

#第 1 レベルのディレクトリ メソッド
#RewriteBase /
#第 2 レベルのディレクトリ メソッド
RewriteBase /listFile/
RewriteCond %{REQUEST_FILENAME} !-f
の RewriteEngine RewriteRule ( .*)index.php?return=%{REQUEST_FILENAME} [L]
*/
?>


JS ファイル



コードをコピーします

コードは次のとおりです:



$(document).ready(function(){

// ルート ノードを削除し、リンクを返しますif(window.location. href ==base_url) $("#back").hide(); //リターン処理$("#back a").click(function() { if(autoClickUrl != ''){

//クリックバック用の baddir を追加します。

var url = autoClickUrl;
var url=window.location.href;
}
if( url ==base_url) return false; // ルート ノードでリターン リンクがトリガーされた場合は、直接戻ります
url = url.replace(location.search,'') / /リンクに ?return が付いている場合は、return を切り詰めます。コンテンツ (.htaccess によって生成)
url = url.substr(0,url.length-2); // ジャンプを避けるため、URL の後の 2 番目の位置から開始します。 /# 状況が存在する場合のエラー
url = url .substr(0,url.lastIndexOf('/') 1); //フォルダーの最後の層を切り捨て、1 レベル前に戻ります
window.location.href = url;
return false; //処理が完了しました。 タグをクリックした後のジャンプを防ぐために false を返します。
if(autoClickUrl != '') a").click()
});


CSS ファイル



コードをコピー

コードは次のとおりです。

#container{
ボーダー: 1px ソリッド;
マージン: 0 自動;

幅: 654px; ボーダー半径: 10px 10px 10px 10px; #back{ width: 654px; margin: 0 auto;

#back a{

line-style:none; 🎜>}
.file{
クリア: 両方;
マージン-ボトム: 20px;
}
.file img{
float:left;
}
.file a{
float: left;
margin-left: 5px;
}
.file div{
float:left; 150px;
}
.text-left{
text-align:left;
.text-center{
text-align:center; >.text-right{
text-align:right;
}
.border-left{
border-left:1px ソリッド;
.border-right{
border-right:1px ソリッド;
}
.file div.filename{
width:200px;
}
.file div.filesize{
width:100px; 🎜>}
.file div.filemtime{
width :200px;
}


.htaccess ファイル



コードをコピー

コードは次のとおりです:


#Principle: アクセス パスはファイル、つまりフォルダーではないため、分析のためにルート パスにジャンプしてすべてを取得して一覧表示します。現在のディレクトリ内のファイル。

#第 1 レベルのディレクトリ メソッド
#RewriteBase /
#第 2 レベルのディレクトリ メソッド
RewriteBase /listFile/
RewriteCond %{REQUEST_FILENAME} !-f
の RewriteEngine RewriteRule ( .*)index.php?return=%{REQUEST_FILENAME} [L]


コアフォルダー: listFile/images/

レンダリングは次のとおりです:
//listFile

パッケージのダウンロード: ダウンロード

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のおすすめ
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート