PHP多文件上传函数

封装的函数

<?php
/*
 *@获取数组信息
 *@三维数组转化为二位数组
 */
function getFiles() {
   $i=0;
   foreach ($_FILES as $file) {
     if(is_string($file['name'])){
          $files[$i]=$file;
          $i++;
     }elseif(is_array($file['name'])){
       foreach ($file['name'] as $key => $value) {
          $files[$i]['name']=$file['name'][$key];
          $files[$i]['type']=$file['type'][$key];
          $files[$i]['tmp_name']=$file['tmp_name'][$key];
          $files[$i]['error']=$file['error'][$key];
          $files[$i]['size']=$file['size'][$key];
          $i++; 
       }
     }
   }
   return $files;
}
/*
*多文件上传
 */

function uploadFile($fileInfo,$flag=true,$path='./uploads',$maxSize=1048576$allowExt=array('jpeg','jpg','png','gif','wbmp')) {
    //判断错误号
    if($fileInfo['error']===UPLOAD_ERR_OK){

       //检测上传的大小
       if($fileInfo['size']>$maxSize){

          $res['msg']=$fileInfo['name'].'上传文件过大';
       }

       //检测上传文件的类型
       // $allowExt=array('jpeg','jpg','png','gif','wbmp');
        $ext=getExt($fileInfo['name']);
       if(!in_array($ext,$allowExt)){

          $res['msg']=$fileInfo['name'].'非法文件类型';

       }

       //检测是否是真实的图片类型
       // $flag=true;
       if($flag){
       if(!getimagesize($fileInfo['tmp_name'])){

           $res['msg']=$fileInfo['name'].'不是真正的图片类型';
       }
     }

        //检测文件是否是通过HTTP POST方式上传的
       if(!is_uploaded_file($fileInfo['tmp_name'])){

      $res['msg']=$fileInfo['name'].'文件不是通过HTTP POST方式上传的合法文件';

    }
       //上传文件  
     if($res) return $res;
     // $path='./uploads';
      if(!file_exists($path)){
       mkdir($path,0777,true);
       chmod($path,0777);
     }

    $uriName=getUniName();
     $destination=$path.'/'.$uriName.'.'.$ext;

     if(!move_uploaded_file($fileInfo['tmp_name'],$destination)){
          
          $res['msg']=$fileInfo['name'].'文件移动失败';
     }
         //文件上传成功
         $res['msg']=$fileInfo['name'].'文件上传成功';
         $res['dest']=$destination;
         return $res;


    }else{

   switch ($fileInfo['error']) {
       case 1:
      $res['msg']= '上传文件超过了PHP配置文件中upload_max_filesize选项的值';
         break;
       case 2:
         $res['msg']= '超过了表单MAX_FTLE_SIZE限制的大小';
         break;
      case 3:
         $res['msg']='文件部分被上传';
         break;
      case 4:
         $res['msg']= '没有选择上传文件';
         break;
      case 6:
         $res['msg']= '没有找到临时目录';
         break;
      case 7:
      case 8:
         $res['msg']= '系统错误';
         break;
    }
         return $res;
    }
}
/*
 *得到扩展名
 */
function getExt($filename){
   return strtolower(pathinfo($filename,PATHINFO_EXTENSION));
}

/*
*得到唯一文件名
 */
function getUniName(){
   return md5(uniqid(microtime(true),true));
}

// 过滤空值,新数组输出
// $uploadFiles = array_values(array_filter($uploadFiles));

<?php
/*
 *@获取数组信息
 *@三维数组转化为二位数组
 */
function getFiles() {
   $i=0;
   foreach ($_FILES as $file) {
     if(is_string($file['name'])){
          $files[$i]=$file;
          $i++;
     }elseif(is_array($file['name'])){
       foreach ($file['name'] as $key => $value) {
          $files[$i]['name']=$file['name'][$key];
          $files[$i]['type']=$file['type'][$key];
          $files[$i]['tmp_name']=$file['tmp_name'][$key];
          $files[$i]['error']=$file['error'][$key];
          $files[$i]['size']=$file['size'][$key];
          $i++;
       }
     }
   }
   return $files;
}
/*
*多文件上传
 */

function uploadFile($fileInfo,$flag=true,$path='./uploads',$maxSize=1048576$allowExt=array('jpeg','jpg','png','gif','wbmp')) {
    //判断错误号
    if($fileInfo['error']===UPLOAD_ERR_OK){

       //检测上传的大小
       if($fileInfo['size']>$maxSize){

          $res['msg']=$fileInfo['name'].'上传文件过大';
       }

       //检测上传文件的类型
       // $allowExt=array('jpeg','jpg','png','gif','wbmp');
        $ext=getExt($fileInfo['name']);
       if(!in_array($ext,$allowExt)){

          $res['msg']=$fileInfo['name'].'非法文件类型';

       }

       //检测是否是真实的图片类型
       // $flag=true;
       if($flag){
       if(!getimagesize($fileInfo['tmp_name'])){

           $res['msg']=$fileInfo['name'].'不是真正的图片类型';
       }
     }

        //检测文件是否是通过HTTP POST方式上传的
       if(!is_uploaded_file($fileInfo['tmp_name'])){

      $res['msg']=$fileInfo['name'].'文件不是通过HTTP POST方式上传的合法文件';

    }
       //上传文件  
     if($res) return $res;
     // $path='./uploads';
      if(!file_exists($path)){
       mkdir($path,0777,true);
       chmod($path,0777);
     }

    $uriName=getUniName();
     $destination=$path.'/'.$uriName.'.'.$ext;

     if(!move_uploaded_file($fileInfo['tmp_name'],$destination)){
          
          $res['msg']=$fileInfo['name'].'文件移动失败';
     }
         //文件上传成功
         $res['msg']=$fileInfo['name'].'文件上传成功';
         $res['dest']=$destination;
         return $res;


    }else{

   switch ($fileInfo['error']) {
       case 1:
      $res['msg']= '上传文件超过了PHP配置文件中upload_max_filesize选项的值';
         break;
       case 2:
         $res['msg']= '超过了表单MAX_FTLE_SIZE限制的大小';
         break;
      case 3:
         $res['msg']='文件部分被上传';
         break;
      case 4:
         $res['msg']= '没有选择上传文件';
         break;
      case 6:
         $res['msg']= '没有找到临时目录';
         break;
      case 7:
      case 8:
         $res['msg']= '系统错误';
         break;
    }
         return $res;
    }
}
/*
 *得到扩展名
 */
function getExt($filename){
   return strtolower(pathinfo($filename,PATHINFO_EXTENSION));
}

/*
*得到唯一文件名
 */
function getUniName(){
   return md5(uniqid(microtime(true),true));
}

 
// 过滤空值,新数组输出
// $uploadFiles = array_values(array_filter($uploadFiles));
view

<!-- multiple选择多个文件上传 -->
<input type="file" name="myFile[]" multiple="multiple"/><br>
<input type="submit" value="上传文件" /><br>
 
<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <title>文件上传</title>
</head>
<body>
   <form action="morefile.php" method="post" enctype="multipart/form-data">
           <span>请上传您的文件:</span>
         <input type="file" name="myFile[]"/><br>
         <span>请上传您的文件:</span>
         <input type="file" name="myFile[]"/><br>
         <span>请上传您的文件:</span>
         <input type="file" name="myFile[]"/><br>
         <span>请上传您的文件:</span>
         
         <input type="submit" value="上传文件" /><br>
   </form>

</body>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 好的,以下是一个简单的 PHP 文件上传函数的封装示例: ``` function uploadFile($file, $targetDir) { $targetFile = $targetDir . basename($file["name"]); $uploadOk = 1; $imageFileType = strtolower(pathinfo($targetFile,PATHINFO_EXTENSION)); // 检查文件是否已经存在 if (file_exists($targetFile)) { echo "抱歉,文件已经存在。"; $uploadOk = 0; } // 检查文件大小 if ($file["size"] > 500000) { echo "抱歉,文件太大。"; $uploadOk = 0; } // 允许上传的文件格式 if($imageFileType != "jpg" && $imageFileType != "png" && $imageFileType != "jpeg" && $imageFileType != "gif" ) { echo "抱歉,只允许上传 JPG, JPEG, PNG 和 GIF 格式的文件。"; $uploadOk = 0; } // 检查 $uploadOk 是否为 0 if ($uploadOk == 0) { echo "抱歉,文件未上传。"; // 如果一切都正常,尝试上传文件 } else { if (move_uploaded_file($file["tmp_name"], $targetFile)) { echo "文件 ". basename( $file["name"]). " 已经上传。"; } else { echo "抱歉,文件上传失败。"; } } } ``` 你可以将这个函数保存在一个单独的 PHP 文件中,然后在你的项目中包含它,以便在需要上传文件时调用它。 ### 回答2: PHP是一种流行的服务器端脚本语言,用于开发Web应用程序。在Web应用程序中,文件上传是常见的功能。下面是一个简单的封装了文件上传功能的PHP函数: ```php function uploadFile($file, $targetDir) { // 检查目标文件夹是否存在,如果不存在则创建 if (!file_exists($targetDir)) { mkdir($targetDir, 0777, true); } // 获取文件名和文件路径 $fileName = $file['name']; $filePath = $targetDir . '/' . $fileName; // 移动上传的文件到目标文件夹 if (move_uploaded_file($file['tmp_name'], $filePath)) { return "文件上传成功"; } else { return "文件上传失败"; } } ``` 这个函数接受两个参数:`$file`和`$targetDir`。`$file`是包含上传文件信息的数组,通常是`$_FILES['file']`,其中`'file'`是HTML表单中文件上传字段的名称。`$targetDir`是要保存上传文件的目标文件夹路径。 在函数内部,我们首先检查目标文件夹是否存在,如果不存在则创建。然后获取上传文件的原始文件名和目标文件路径。最后,我们使用`move_uploaded_file`函数将上传的临时文件移动到目标文件夹。如果移动成功,函数返回"文件上传成功",否则返回"文件上传失败"。 这个函数只是一个简单的文件上传功能示例,实际使用中可能还需要进行文件类型和大小的验证,以及对上传文件名的处理。此外,为了安全考虑,我们可能还需要对上传文件进行进一步的检查和过滤,以防止恶意文件上传和执行。 ### 回答3: PHP文件上传函数的封装包括以下几个步骤: 1. 创建一个函数,使用`function`关键字,命名为`uploadFile`,并接受一个参数`$file`,代表文件的相关信息。 2. 在函数内部,首先判断文件是否成功上传,使用`isset`函数判断`$file`是否存在以及`$file['error']`是否等于`UPLOAD_ERR_OK`。 3. 如果文件上传成功,继续对文件进行处理。可以先定义一个数组来保存可能遇到的错误信息,如`$errors = array()`。 4. 判断文件大小是否符合要求,可以通过`$file['size']`与指定的最大文件大小进行比较。如果超过最大值,将错误信息添加到`$errors`数组中。 5. 判断文件的类型是否符合要求,可以通过`$file['type']`与指定的允许类型进行比较。如果不在允许的类型范围内,将错误信息添加到`$errors`数组中。 6. 如果上述验证都通过,可以将文件移动到指定的上传目录。可以使用`move_uploaded_file`函数实现文件的移动,其中第一个参数为`$file['tmp_name']`表示临时存储的路径,第二个参数为指定的上传目录和文件名。 7. 最后,函数应该返回一个数组,包含两个元素。一个是表示操作是否成功的`success`,可以通过检查`$errors`数组是否为空来判断。另一个是保存错误信息的`errors`数组,如果有错误的话。 整个函数的代码如下: ``` function uploadFile($file) { if (isset($file) && $file['error'] === UPLOAD_ERR_OK) { $errors = array(); // 验证文件大小 $maxSize = 10 * 1024 * 1024; // 假设最大文件大小为10MB if ($file['size'] > $maxSize) { $errors[] = '文件大小超过限制'; } // 验证文件类型 $allowedTypes = array('image/jpeg', 'image/png'); // 假设只允许上传JPEG和PNG图片 if (!in_array($file['type'], $allowedTypes)) { $errors[] = '文件类型不被允许'; } // 将文件移动到上传目录 $uploadDirectory = 'uploads/'; // 假设上传目录为当前目录下的uploads文件夹 $destination = $uploadDirectory . $file['name']; move_uploaded_file($file['tmp_name'], $destination); return array( 'success' => empty($errors), 'errors' => $errors ); } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值