日韩天天综合网_野战两个奶头被亲到高潮_亚洲日韩欧美精品综合_av女人天堂污污污_视频一区**字幕无弹窗_国产亚洲欧美小视频_国内性爱精品在线免费视频_国产一级电影在线播放_日韩欧美内地福利_亚洲一二三不卡片区

PHP遍歷文件夾與文件類及處理類用法實例_PHP教程

編輯Tag賺U幣
教程Tag:暫無Tag,歡迎添加,賺取U幣!

推薦:php禁止直接從瀏覽器輸入地址訪問.PHP文件
比如說我http://www.111cn.net /xx.php 這個文件我不想讓別人直接從瀏覽器輸入地址訪問 但是如果從任何網(wǎng)站連接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,即頭三個字節(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;

  }

  }

  /** 重寫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); // 去掉頭三個字節(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);

  ?>

  希望本文所述對大家PHP程序設計的學習有所幫助。

分享:php驗證session無效問題解決辦法
環(huán)境,我用的是apache+php環(huán)境了 如我的程序代碼如下 結果發(fā)現(xiàn)一直提示驗證碼必須由4位數(shù)字組成,我再打印輸出session echo $_SESSION['ssioner'];exit; 一直為空了,于時我想到了php環(huán)境配置的一個session文件目錄,現(xiàn)在我們找到php.ini配置文件找到 upload_tmp_dir 發(fā)

來源:模板無憂//所屬分類:PHP教程/更新時間:2014-10-10
相關PHP教程