搜尋
首頁後端開發php教程php文件上传类与详解(1/2)_PHP教程

php文件上传类与详解(1/2)_PHP教程

Jul 20, 2016 am 11:09 AM
dirphptmp上傳參數教學文件比較類別詳解這個進行配置

php教程 配置中的 upload_tmp_dir 这个参数进行比较,如果文件在这个目录下面,那么 move_uploaded_file 才会进行移动操作。而且这个比较是大小写敏感,/ 在windows 下面也是不一样的。而在php配置文件解析的时候,会调用一个realpath 函数,也就是是说,你在move_uploaded_file 之前,


必须对$file['tmp_name'] = realpath($file['tmp_name']); realpath 一下。


    还有一种情况,大家要注意,就是 move_uploaded_file  如果配置成一个无法访问的路径,那么你不管怎么处理,move_uploaded_file 总是不能成功移动文件。


在文件上传的时候,用 move_uploaded_file 这个函数不能移动文件,而用copy 或者 rename 确是可以的。


我也一直很困惑。在文档上,说的比较模糊,就是 move_uploaded_file 这个函数,加了一步检查,检查这个文件是否是有 http post 上传的,


下面我在网上找到一个文件上传类

**文件上传类**/
 
 

class upload_file
 {
  /**声明**/
  var $upfile_type,$upfile_size,$upfile_name,$upfile;
  var $d_alt,$extention_list,$tmp,$arri;
  var $datetime,$date;
  var $filestr,$size,$ext,$check;
  var $flash_directory,$extention,$file_path,$base_directory;
  var $url; //文件上传成功后跳转路径;
 
  function upload_file()
  {
   /**构造函数**/
   $this->set_url("index.php");          //初始化上传成功后跳转路径;
   $this->set_extention();             //初始化扩展名列表;
   $this->set_size(50);              //初始化上传文件kb限制;
   $this->set_date();               //设置目录名称;
   $this->set_datetime();             //设置文件名称前缀;
   $this->set_base_directory("attachmentfile");  //初始化文件上传根目录名,可修改!;
  }
 
  /**文件类型**/
  function set_file_type($upfile_type)
  {
   $this->upfile_type = $upfile_type;       //取得文件类型;
  }
 
  /**获得文件名**/
  function set_file_name($upfile_name)
  {
   $this->upfile_name = $upfile_name;       //取得文件名称;
  }
 
  /**获得文件**/
  function set_upfile($upfile)
  {
   $this->upfile = $upfile;            //取得文件在服务端储存的临时文件名;
  }
   
  /**获得文件大小**/
  function set_file_size($upfile_size)
  {
   $this->upfile_size = $upfile_size;       //取得文件尺寸;
  }
 
  /**设置文件上传成功后跳转路径**/
  function set_url($url)
  {
   $this->url = $url;               //设置成功上传文件后的跳转路径;
  }
 
  /**获得文件扩展名**/
  function get_extention()
  {
    $this->extention = preg_replace('/.*.(.*[^.].*)*/iu','1',$this->upfile_name); //取得文件扩展名;
  }
     
  /**设置文件名称**/
  function set_datetime()
  {
   $this->datetime = date("ymdhis");        //按时间生成文件名;
  }
 
  /**设置目录名称**/
  function set_date()
  {
   $this->date = date("y-m-d");          //按日期生成目录名称;
  }
 
  /**初始化允许上传文件类型**/
  function set_extention()
  {
   $this->extention_list = "doc|xls|ppt|avi|txt|gif|jpg|jpeg|bmp|png"; //默认允许上传的扩展名称;
  } 
 
  /**设置最大上传kb限制**/
  function set_size($size)
  {
   $this->size = $size;              //设置最大允许上传的文件大小;
  }
 
  /**初始化文件存储根目录**/
  function set_base_directory($directory)
  {
   $this->base_directory = $directory; //生成文件存储根目录;
  }
 
  /**初始化文件存储子目录**/
  function set_flash_directory()
  {
   $this->flash_directory = $this->base_directory."/".$this->date; //生成文件存储子目录;
  }
 
  /**错误处理**/
  function showerror($errstr="未知错误!"){
   echo "";
   exit();
  }
 
  /**跳转**/
  function go_to($str,$url)
  {
   echo "";
   exit();
  }

  /**如果根目录没有创建则创建文件存储目录**/
  function mk_base_dir()
  {
   if (! file_exists($this->base_directory)){   //检测根目录是否存在;
    @mkdir($this->base_directory,0777);     //不存在则创建;
   }
  }

  /**如果子目录没有创建则创建文件存储目录**/
  function mk_dir()
  {
   if (! file_exists($this->flash_directory)){   //检测子目录是否存在;
    @mkdir($this->flash_directory,0777);     //不存在则创建;
   }
  } 
 
  /**以数组的形式获得分解后的允许上传的文件类型**/
  function get_compare_extention()
  {
   $this->ext = explode("|",$this->extention_list);//以"|"来分解默认扩展名;
  }
 
  /**检测扩展名是否违规**/
  function check_extention()
  {
   for($i=0;each($this->ext);$i++)            //遍历数组;
   {
    if($this->ext[$i] == strtolower($this->extention)) //比较文件扩展名是否与默认允许的扩展名相符;
    {
     $this->check = true;               //相符则标记;
     break;
    }
   }
   if(!$this->check){$this->showerror("正确的扩展名必须为".$this->extention_list."其中的一种!");}
   //不符则警告
  }
 
  /**检测文件大小是否超标**/
  function check_size()
  {
   if($this->upfile_size > round($this->size*1024))     //文件的大小是否超过了默认的尺寸;
   {
    $this->showerror("上传附件不得超过".$this->size."kb"); //超过则警告;
   }
  }

  /**文件完整访问路径**/
  function set_file_path()
  {
   $this->file_path = $this->flash_directory."/".$this->datetime.".".$this->extention; //生成文件完整访问路径;
  }
 
  /**上传文件**/
  function copy_file()
  {
   if(copy($this->upfile,$this->file_path)){        //上传文件;
    print $this->go_to("文件已经成功上传!",$this->url);  //上传成功;
   }else {
    print $this->showerror("意外错误,请重试!");     //上传失败;
   }
  }
 
  /**完成保存**/
  function save()
  {
   $this->set_flash_directory();  //初始化文件上传子目录名;
   $this->get_extention();     //获得文件扩展名;
   $this->get_compare_extention(); //以"|"来分解默认扩展名;
   $this->check_extention();    //检测文件扩展名是否违规;
   $this->check_size();      //检测文件大小是否超限;  
   $this->mk_base_dir();      //如果根目录不存在则创建;
   $this->mk_dir();        //如果子目录不存在则创建;
   $this->set_file_path();     //生成文件完整访问路径;
   $this->copy_file();       //上传文件;
  }
 
 }

1 2

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/444804.htmlTechArticlephp教程 配置中的 upload_tmp_dir 这个参数进行比较,如果文件在这个目录下面,那么 move_uploaded_file 才会进行移动操作。而且这个比较是大小写...
陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
可以在PHP會話中存儲哪些數據?可以在PHP會話中存儲哪些數據?May 02, 2025 am 12:17 AM

phpsessionscanStorestrings,數字,數組和原始物。

您如何開始PHP會話?您如何開始PHP會話?May 02, 2025 am 12:16 AM

tostartaphpsession,usesesses_start()attheScript'Sbeginning.1)placeitbeforeanyOutputtosetThesessionCookie.2)useSessionsforuserDatalikeloginstatusorshoppingcarts.3)regenerateSessiveIdStopreventFentfixationAttacks.s.4)考慮使用AttActAcks.s.s.4)

什麼是會話再生,如何提高安全性?什麼是會話再生,如何提高安全性?May 02, 2025 am 12:15 AM

會話再生是指在用戶進行敏感操作時生成新會話ID並使舊ID失效,以防會話固定攻擊。實現步驟包括:1.檢測敏感操作,2.生成新會話ID,3.銷毀舊會話ID,4.更新用戶端會話信息。

使用PHP會話時有哪些性能考慮?使用PHP會話時有哪些性能考慮?May 02, 2025 am 12:11 AM

PHP会话对应用性能有显著影响。优化方法包括:1.使用数据库存储会话数据,提升响应速度;2.减少会话数据使用,只存储必要信息;3.采用非阻塞会话处理器,提高并发能力;4.调整会话过期时间,平衡用户体验和服务器负担;5.使用持久会话,减少数据读写次数。

PHP會話與Cookie有何不同?PHP會話與Cookie有何不同?May 02, 2025 am 12:03 AM

PHPsessionsareserver-side,whilecookiesareclient-side.1)Sessionsstoredataontheserver,aremoresecure,andhandlelargerdata.2)Cookiesstoredataontheclient,arelesssecure,andlimitedinsize.Usesessionsforsensitivedataandcookiesfornon-sensitive,client-sidedata.

PHP如何識別用戶的會話?PHP如何識別用戶的會話?May 01, 2025 am 12:23 AM

phpIdentifiesauser'ssessionSessionSessionCookiesAndSessionId.1)whiwsession_start()被稱為,phpgeneratesainiquesesesessionIdStoredInacookInAcookInAcienamedInAcienamedphpsessIdontheuser'sbrowser'sbrowser.2)thisIdallowSphptpptpptpptpptpptpptpptoretoreteretrieetrieetrieetrieetrieetrieetreetrieetrieetrieetrieetremthafromtheserver。

確保PHP會議的一些最佳實踐是什麼?確保PHP會議的一些最佳實踐是什麼?May 01, 2025 am 12:22 AM

PHP會話的安全可以通過以下措施實現:1.使用session_regenerate_id()在用戶登錄或重要操作時重新生成會話ID。 2.通過HTTPS協議加密傳輸會話ID。 3.使用session_save_path()指定安全目錄存儲會話數據,並正確設置權限。

PHP會話文件默認存儲在哪裡?PHP會話文件默認存儲在哪裡?May 01, 2025 am 12:15 AM

phpsessionFilesArestoredIntheDirectorySpecifiedBysession.save_path,通常是/tmponunix-likesystemsorc:\ windows \ windows \ temponwindows.tocustomizethis:tocustomizEthis:1)useession_save_save_save_path_path()

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。