PHP遍歷文件夾與文件類及處理類用法實(shí)例_PHP教程
推薦:php禁止直接從瀏覽器輸入地址訪問(wèn).PHP文件比如說(shuō)我http://www.111cn.net /xx.php 這個(gè)文件我不想讓別人直接從瀏覽器輸入地址訪問(wèn) 但是如果從任何網(wǎng)站連接http://www.111cn.net /xx.php過(guò)來(lái)就可以訪問(wèn) 本機(jī)建立連接也無(wú)法訪問(wèn)跳轉(zhuǎn)到另外的地址 1.在xx.php文件頭部寫(xiě)上以下代碼就可以了 $fromurl=http://www.111c
本文實(shí)例講述了PHP遍歷文件夾與文件類及處理類用法,非常具有實(shí)用價(jià)值。分享給大家供大家參考。具體方法如下:
FindFile.class.php類文件用于遍歷目錄文件,具體代碼如下:
<?php
/** 遍歷文件夾及文件類
* Date: 2013-03-21
* Author: fdipzone
* Ver: 1.0
*/
class FindFile{
public $files = array(); // 存儲(chǔ)遍歷的文件
protected $maxdepth; // 搜尋深度,0表示沒(méi)有限制
/* 遍歷文件及文件夾
* @param String $spath 文件夾路徑
* @param int $maxdepth 搜尋深度,默認(rèn)搜尋全部
*/
public function process($spath, $maxdepth=0){
if(isset($maxdepth) && is_numeric($maxdepth) && $maxdepth>0){
$this->maxdepth = $maxdepth;
}else{
$this->maxdepth = 0;
}
$this->files = array();
$this->traversing($spath); // 遍歷
}
/* 遍歷文件及文件夾
* @param String $spath 文件夾路徑
* @param int $depth 當(dāng)前文件夾深度
*/
private function traversing($spath, $depth=1){
if($handle = opendir($spath)){
while(($file=readdir($handle))!==false){
if($file!='.' && $file!='..'){
$curfile = $spath.'/'.$file;
if(is_dir($curfile)){ // dir
if($this->maxdepth==0 || $depth<$this->maxdepth){ // 判斷深度
$this->traversing($curfile, $depth+1);
}
}else{ // file
$this->handle($curfile);
}
}
}
closedir($handle);
}
}
/** 處理文件方法
* @param String $file 文件路徑
*/
protected function handle($file){
array_push($this->files, $file);
}
}
?>
UnsetBom.class.php用于清除utf8+bom文件的bom,即頭三個(gè)字節(jié) 0xEF 0xBB 0xBF,繼承FindFile類,具體代碼如下:
<?php
/** 遍歷所有文件,清除utf8+bom 0xEF 0xBB 0xBF
* Date: 2013-03-21
* Author: fdipzone
* Ver: 1.0
*/
class UnsetBom extends FindFile{
private $filetype = array(); // 需要處理的文件類型
// 初始化
public function __construct($filetype=array()){
if($filetype){
$this->filetype = $filetype;
}
}
/** 重寫(xiě)FindFile handle方法
* @param String $file 文件路徑
*/
protected function handle($file){
if($this->check_ext($file) && $this->check_utf8bom($file)){ // utf8+bom
$this->clear_utf8bom($file); // clear
array_push($this->files, $file); // save log
}
}
/** 檢查文件是否utf8+bom
* @param String $file 文件路徑
* @return boolean
*/
private function check_utf8bom($file){
$content = file_get_contents($file);
return ord(substr($content,0,1))===0xEF && ord(substr($content,1,1))===0xBB && ord(substr($content,2,1))===0xBF;
}
/** 清除utf8+bom
* @param String $file 文件路徑
*/
private function clear_utf8bom($file){
$content = file_get_contents($file);
file_put_contents($file, substr($content,3), true); // 去掉頭三個(gè)字節(jié)
}
/** 檢查文件類型
* @param String $file 文件路徑
* @return boolean
*/
private function check_ext($file){
$file_ext = strtolower(array_pop(explode('.',basename($file))));
if(in_array($file_ext, $this->filetype)){
return true;
}else{
return false;
}
}
}
?>
去除utf8 bom頭Demo遍歷文件示例:
<?php
require('FindFile.class.php');
require('UnsetBom.class.php');
$folder = dirname(__FILE__);
$obj = new UnsetBom(array('php','css','js')); // 文件類型
$obj->process($folder);
print_r($obj->files);
?>
希望本文所述對(duì)大家PHP程序設(shè)計(jì)的學(xué)習(xí)有所幫助。
分享:php驗(yàn)證session無(wú)效問(wèn)題解決辦法環(huán)境,我用的是apache+php環(huán)境了 如我的程序代碼如下 結(jié)果發(fā)現(xiàn)一直提示驗(yàn)證碼必須由4位數(shù)字組成,我再打印輸出session echo $_SESSION['ssioner'];exit; 一直為空了,于時(shí)我想到了php環(huán)境配置的一個(gè)session文件目錄,現(xiàn)在我們找到php.ini配置文件找到 upload_tmp_dir 發(fā)
- php禁止直接從瀏覽器輸入地址訪問(wèn).PHP文件
- php驗(yàn)證session無(wú)效問(wèn)題解決辦法
- php過(guò)濾html標(biāo)記屬性類用法實(shí)例
- php中unserialize返回false的解決方法
- PHP實(shí)現(xiàn)AES256加密算法實(shí)例
- php生成QRcode實(shí)例
- php生成16位隨機(jī)數(shù)的代碼
- PHP中date與gmdate有什么區(qū)別?
- php的XML文件解釋類應(yīng)用實(shí)例
- PHP郵件發(fā)送類PHPMailer用法實(shí)例詳解
- php實(shí)現(xiàn)的CSS更新類實(shí)例
- php實(shí)現(xiàn)的返回?cái)?shù)據(jù)格式化類實(shí)例
- 相關(guān)鏈接:
- 教程說(shuō)明:
PHP教程-PHP遍歷文件夾與文件類及處理類用法實(shí)例
。