php文件服務(wù)實(shí)現(xiàn)虛擬掛載其他目錄示例
php文件服務(wù)實(shí)現(xiàn)虛擬掛載其他目錄
<?php
function base64url_encode($data) {
return rtrim(strtr(base64_encode($data), '+/', '-_'), '=');
}
function base64url_decode($data) {
return base64_decode(str_pad(strtr($data, '-_', '+/'), strlen($data) % 4, '=', STR_PAD_RIGHT));
}
function array_verify($var)
{
return isset($var)&&is_array($var) && count($var)>0;
}
function format_file_size($var)
{
if($var<1024) return $var.' B';
if($var<1048576) return ($var/1024.0).' K';
if($var<1073741824) return ($var/1048576.0).' M';
return ($var/1073741824.0).' G';
}
$dir="F:";//不以/結(jié)尾
$path="";
if(array_verify($_GET)&&isset($_GET["path"]))
{
$path=base64url_decode($_GET["path"]);
preg_match("#^[^/].*$|^.*\.$|^\..*$|\./\.|/\.|\./#",$path,$temp);
if(array_verify($temp))
{
echo
'<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=gb2312" />
<body>';
echo "警告 index.php?path=".$_GET["path"]." 非法url<br/></body></html>";
exit;
}
$path=preg_replace("#[/\/]{2,}#","/",$path);
}
if(is_dir($dir.$path))
{
echo '<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=gb2312" />
<body>';
echo "目錄 <b>".$path."</b><br/><br/>";
$dir_res=opendir($dir.$path);
while($filen=readdir($dir_res))
{
if($filen!='.'&&$filen!='..')
{
if(is_file($dir.$path.'/'.$filen))
{
echo '<a href="index.php?path='.base64url_encode($path.'/'.$filen).'" >'.$filen.'</a> ('.format_file_size(filesize($dir.$path.'/'.$filen)).")<br/>\n";
}else
{
echo '<a href="index.php?path='.base64url_encode($path.'/'.$filen).'" >'.$filen."</a><br/>\n";
}
}else if($filen=='..')
{
preg_match("#([^/]+/{1})*[^/]+(?=/)#",$path,$parent);
if(array_verify($parent))
{
echo '<a href="index.php?path='.base64url_encode('/'.$parent[0]).'" >'.$filen."</a><br/>\n";
}else
{
echo '<a href="index.php?path='.base64url_encode('/').'" >'.$filen."</a><br/>\n";
}
}
}
echo '</body>
</html>';
}
else if(is_file($dir.$path))
{
$file_size = filesize($dir.$path);
header("Content-type: application/octet-stream");
header("Accept-Ranges: bytes");
header("Accept-Length: ".$file_size);
Header("Content-Disposition: attachment; filename=".basename($dir.$path));
readfile($dir.$path);//大文件請(qǐng)選擇其他方式
}else
echo "警告:非法訪問(wèn)!";
?>
相關(guān)文章
yii2框架中使用下拉菜單的自動(dòng)搜索yii-widget-select2實(shí)例分析
這篇文章主要介紹了yii2框架中使用下拉菜單的自動(dòng)搜索yii-widget-select2的方法,介紹了yii-widget-select2的下載,安裝及具體使用技巧,需要的朋友可以參考下2016-01-01
PHP中cookie和session的區(qū)別實(shí)例分析
這篇文章主要介紹了PHP中cookie和session的區(qū)別,比較詳盡的分析了二者從創(chuàng)建、運(yùn)用到清除的各個(gè)流程的注意事項(xiàng),需要的朋友可以參考下2014-08-08
跟我學(xué)Laravel之請(qǐng)求(Request)的生命周期
這篇文檔包含了關(guān)于請(qǐng)求生命周期的高層次概述,以及啟動(dòng)文件和應(yīng)用程序事件的相關(guān)內(nèi)容。是篇非常不錯(cuò)的文章,有需要的朋友可以參考下2014-10-10
php中hashtable實(shí)現(xiàn)示例分享
對(duì)php內(nèi)核有一定了解的人應(yīng)該都知道php的精髓就是HashTable,這篇文章主要介紹了php中hashtable實(shí)現(xiàn)示例,需要的朋友可以參考下2014-02-02
php下拉選項(xiàng)的批量操作的實(shí)現(xiàn)代碼
這篇文章介紹了php下拉選項(xiàng)的批量操作的實(shí)現(xiàn)代碼,有需要的朋友可以參考一下2013-10-10
分享8個(gè)Laravel模型時(shí)間戳使用技巧小結(jié)
這篇文章主要介紹了分享8個(gè)Laravel模型時(shí)間戳使用技巧小結(jié),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02

