php多文件上传 多图片上传程序代码
多文件上传其实就包括了图片及各种文件了,下面介绍的是一款PHP多文件上传类,一共两个文件,upp.php 和 uploadFile.php,upp.php,这是前台所显示的表单文件了,默认的是四个上传文件域,我们可以手动进行修改,另外这个页面嵌套了 uploadFile.php 文件上传类,下面一起来看例子。
文件上传例子
<?php header('content-type:text/html;charset=utf-8'); require ('uploadFile.php'); if (isset($_POST['submit'])) { $uploads = $_FILES['file']; $num_file = count($uploads['name']); $up = new UploadFile($uploads, 'uploads', 1024); $num = $up->upload(); if ($num == $num_file) { echo '全部文件上传成功'; exit; } else { echo $num, '个文件上传成功<br/>'; echo $up->showErrorInfo(); exit; } } ?>
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>无标题文档</title> </head> <body> <form action="uup.php" method="post" enctype="multipart/form-data"> <p><input name="file[]" type="file" /></p> <p><input name="file[]" type="file" /></p> <p><input name="file[]" type="file" /></p> <p><input name="file[]" type="file" /></p> <input name="submit" type="submit" /> </form> </body> </html>
文件上传类代码
<?php /*------------*/ class UploadFile { var $user_post_file = array(); var $save_file_path = ''; var $max_file_size = ''; var $allow_type = array( 'gif', 'jpg', 'png', 'zip', 'rar', 'txt', 'doc', 'pdf' ); var $final_file_path = ''; var $save_info = array(); var $error_info = array(); /** *构造函数,用于初始化信息。 * *@param Array $file *@param String $path *@param Integer $size *@param Array $type */ function __construct($file, $path, $size = 2097152, $type = '') { $this->user_post_file = $file; $this->save_file_path = $path; $this->max_file_size = $size; if (!$type = '') { $this->allow_type[] = $type; } } /** * * *@access public *@return int */ function upload() { for ($i = 0; $i < count($this->user_post_file['name']); $i++) { if ($this->user_post_file['error'][$i] == 0) { //上传文件状态正常 //获取当前文件名,临时文件名,大小,类型,扩展名 $name = $this->user_post_file['name'][$i]; $tmp_name = $this->user_post_file['tmp_name'][$i]; $size = $this->user_post_file['size'][$i]; $type = $this->user_post_file['type'][$i]; $ext_name = $this->getExtName($name); //文件大小 if (!$this->checkSize($size)) { $this->error_info[] = '您上传的文件:' . $name . '太大'; continue; } //扩展名 if (!$this->checkType($ext_name)) { $this->error_info[] = '您上传的文件:' . $name . '不合法'; continue; } //非法上传 if (!is_uploaded_file($tmp_name)) { $this->error_info[] = '您上传的文件:' . $name . '属于非法提交'; continue; } // $basename = $this->getBaseName($name, "." . $ext_name); $final_filename = $basename . '-' . time() . '-' . rand(1, 10000) . '.' . $ext_name; $this->final_file_path = $this->save_file_path . '/' . $final_filename; if (!move_uploaded_file($tmp_name, $this->final_file_path)) { $this->error_info = $this->user_post_file['error'][$i]; continue; } // $this->save_info[] = array( "name" => $name, "ext_name" => $ext_name, "type" => $type, "size" => $size, "final_filename" => $final_filename, "path" => $this->final_file_path ); } } return count($this->save_info); } /* *检查用户上传文件的大小时候合法 * *@param Integer $size *@access private *@return boolean */ function checkSize($size) { if ($size > $this->max_file_size) { return FALSE; } return TRUE; } /* *检查用户上传文件的类型是否合法 * *@access private *@return boolean */ function checkType($extension) { foreach ($this->allow_type as $type) { if (strcasecmp($extension, $type) == 0) { return TRUE; } } return FALSE; } /* *获取文件的扩展名 * *@param string $filename *@access private *@return string */ function getExtName($filename) { $p = pathinfo($filename); return $p['extension']; } /* *获取文件名(不包括扩展名) * *@param string $filename *@param string $type *@access private *@return boolean */ function getBaseName($filename, $ext_name) { $basename = basename($filename, $ext_name); return $basename; } /* * * * */ function showErrorInfo() { if (count($this->error_info) != 0) { //echo 'error...<br/>'; foreach ($this->error_info as $k => $v) { echo ($k + 1) , ':', $v, '<br/>'; } } } function getSaveInfo() { return $this->save_info; } } //$upload = new UploadFile('',''); //$upload = new UploadFile(); //$upload->showErrorInfo(); ?>
本文地址:http://www.phprm.com/base/64847.html
转载随意,但请附上文章地址:-)