PHP遍历文件夹与文件类及处理类用法实例_PHP教程
推荐:php禁止直接从浏览器输入地址访问.PHP文件比如说我http://www.111cn.net /xx.php 这个文件我不想让别人直接从浏览器输入地址访问 但是如果从任何网站连接http://www.111cn.net /xx.php过来就可以访问 本机建立连接也无法访问跳转到另外的地址 1.在xx.php文件头部写上以下代码就可以了 $fromurl=http://www.111c
本文实例讲述了PHP遍历文件夹与文件类及处理类用法,非常具有实用价值。分享给大家供大家参考。具体方法如下:
FindFile.class.php类文件用于遍历目录文件,具体代码如下:
<?php
/** 遍历文件夹及文件类
* Date: 2013-03-21
* Author: fdipzone
* Ver: 1.0
*/
class FindFile{
public $files = array(); // 存储遍历的文件
protected $maxdepth; // 搜寻深度,0表示没有限制
/* 遍历文件及文件夹
* @param String $spath 文件夹路径
* @param int $maxdepth 搜寻深度,默认搜寻全部
*/
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 当前文件夹深度
*/
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,即头三个字节 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;
}
}
/** 重写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); // 去掉头三个字节
}
/** 检查文件类型
* @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);
?>
希望本文所述对大家PHP程序设计的学习有所帮助。
分享:php验证session无效问题解决办法环境,我用的是apache+php环境了 如我的程序代码如下 结果发现一直提示验证码必须由4位数字组成,我再打印输出session echo $_SESSION['ssioner'];exit; 一直为空了,于时我想到了php环境配置的一个session文件目录,现在我们找到php.ini配置文件找到 upload_tmp_dir 发
- 相关链接:
- 教程说明:
PHP教程-PHP遍历文件夹与文件类及处理类用法实例
。