Heim > php教程 > php手册 > Hauptteil

PHP100精华:PHP上传类支持缩略图

WBOY
Freigeben: 2016-06-13 10:37:31
Original
1135 Leute haben es durchsucht

  实例:

  1、创建文件upfile.php,代码如下

  //如果收到表单传来的参数,则进行上传处理,否则显示表单

  if(isset($_FILES[uploadinput])){

  //建目录函数,其中参数$directoryName最后没有"/",

  //要是有的话,以/打散为数组的时候,最后将会出现一个空值

  function makeDirectory($directoryName) {

  $directoryName = str_replace("\","/",$directoryName);

  $dirNames = explode(/, $directoryName);

  $total = count($dirNames) ;

  $temp = ;

  for($i=0; $i

  $temp .= $dirNames[$i]./;

  if (!is_dir($temp)) {

  $oldmask = umask(0);

  if (!mkdir($temp, 0777)) exit("不能建立目录 $temp");

  umask($oldmask);

  }

  }

  return true;

  }

  if($_FILES[uploadinput][name] ""){

  //包含上传文件类

  require_once (class_upload.php);

  //设置文件上传目录

  $savePath = "upload";

  //创建目录

  makeDirectory($savePath);

  //允许的文件类型

  $fileFormat = array(gif,jpg,jpge,png);

  //文件大小限制,单位: Byte,1KB = 1000 Byte //2cto.com

  //0 表示无限制,但受php.ini中upload_max_filesize设置影响

  $maxSize = 0;

  //覆盖原有文件吗? 0 不允许 1 允许

  $overwrite = 0;

  //初始化上传类

  $f = new clsUpload( $savePath, $fileFormat, $maxSize, $overwrite);

  //如果想生成缩略图,则调用成员函数 $f->setThumb();

  //参数列表: setThumb($thumb, $thumbWidth = 0,$thumbHeight = 0)

  //$thumb=1 表示要生成缩略图,不调用时,其值为 0

  //$thumbWidth 缩略图宽,单位是像素(px),留空则使用默认值 130

  //$thumbHeight 缩略图高,单位是像素(px),留空则使用默认值 130

  $f->setThumb(1);

  //参数中的uploadinput是表单中上传文件输入框input的名字

  //后面的0表示不更改文件名,若为1,则由系统生成随机文件名

  if (!$f->run(uploadinput,0)){

  //通过$f->errmsg()只能得到最后一个出错的信息,

  //详细的信息在$f->getInfo()中可以得到。

  echo $f->errmsg()."
";

  }

  //上传结果保存在数组returnArray中。//2cto.com

  echo "

";<p> </p>
<p>  print_r($f->getInfo());</p>
<p>  echo "</p>
Nach dem Login kopieren

";

 

  }

  }else{

  ?>

  

  Send this file:
 

  
 

  
 

  
 

  
 

  

  2、创建文件class_upload.php,代码如下

  

  class clsUpload{

  var $saveName;// 保存名

  var $savePath;// 保存路径

  var $fileFormat = array(gif,jpg,doc,application/octet-stream);// 文件格式&MIME限定

  var $overwrite = 0;// 覆盖模式

  var $maxSize = 0;// 文件最大字节

  var $ext;// 文件扩展名

  var $thumb = 0;// 是否生成缩略图

  var $thumbWidth = 130;// 缩略图宽

  var $thumbHeight = 130;// 缩略图高

  var $thumbPrefix = "_";// 缩略图前缀

  var $errno;// 错误代号

  var $returnArray= array();// 所有文件的返回信息

  var $returninfo= array();// 每个文件返回信息

  // 构造函数

  // @param $savePath 文件保存路径

  // @param $fileFormat 文件格式限制数组

  // @param $maxSize 文件最大尺寸

  // @param $overwriet 是否覆盖 1 允许覆盖 0 禁止覆盖

  function clsUpload($savePath, $fileFormat=,$maxSize = 0, $overwrite = 0) {

  $this->setSavepath($savePath);

  $this->setFileformat($fileFormat);

  $this->setMaxsize($maxSize);

  $this->setOverwrite($overwrite);

  $this->setThumb($this->thumb, $this->thumbWidth,$this->thumbHeight);

  $this->errno = 0;

  }

  // 上传

  // @param $fileInput 网页Form(表单)中input的名称

  // @param $changeName 是否更改文件名

  function run($fileInput,$changeName = 1){

  if(isset($_FILES[$fileInput])){

  $fileArr = $_FILES[$fileInput];

  if(is_array($fileArr[name])){//上传同文件域名称多个文件

  for($i = 0; $i

  $ar[tmp_name] = $fileArr[tmp_name][$i];

  $ar[name] = $fileArr[name][$i];

  $ar[type] = $fileArr[type][$i];

  $ar[size] = $fileArr[size][$i];

  $ar[error] = $fileArr[error][$i];

  $this->getExt($ar[name]);//取得扩展名,赋给$this->ext,下次循环会更新

  $this->setSavename($changeName == 1 ? : $ar[name]);//设置保存文件名

  if($this->copyfile($ar)){

  $this->returnArray[] = $this->returninfo;

  }else{

  $this->returninfo[error] = $this->errmsg();

  $this->returnArray[] = $this->returninfo;

  }

  }

  return $this->errno ? false : true;

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Empfehlungen
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage