php文件上传函数封装教程

此文件是简单php文件上传函数的封装教程

代码如下

// php上传功能函数封装
/*
 * 实现文件(单)
 * $file 需要上传的文件信息
 * $allow_type 允许上传的MIME类型
 * $path 存储的路径
 * &$error如果出现错误的原因
 * $allow_format = array() 允许上传的 文件格式
 * $max_size = 2000000 允许上传的最大值
*/

//封装函数
function upload_single($file, $allow_type, $path, &$error, $allow_format = array(), $max_size = 2000000)
{
    // 判断文件是否有效
    if (!array($file) || !isset($file['error'])) {
        $error = "文件不存在或者无效";
        return false;
    }
    // 判断文件存储的路径是否有效
    if (!is_dir($path)) {
        // 路径不存在
        $error = "文件存储路径不存在或者无效";
        return false;
    }
    // 判断文件上传过程是否出错
    switch ($file['error']) {
        case 1:
        case 2:
            $error = '文件超出服务器允许大小!';
            return false;
        case 3:
            $error = '文件上传过程中出现问题!';
            return false;
        case 4:
            $error = '用户没有选中要上传的文件!';
            return false;
        case 6:
        case 7:
            $error = '文件保存失败!';
            return false;
    }
    // 判断MIME类型
    if (!in_array($file['type'], $allow_type)) {
        // 该文件类型不允许上传
        $error = '该文件类型不允许上传!';
        return false;
    }
    // 判断后缀是否允许
    $ext = ltrim(strchr($file['name'], '.'), '.');
    if (!empty($allow_format) && !in_array($ext, $allow_format)) {
        // 不允许上传
        $error = '当前文件格式不允许上传!';
        return false;
    }
    // 判断当前文件大小是否满足当前需求
    if ($file['size'] > $max_size) {
        $error = '当前上传文件超出大小, 最大' . $max_size . '字节!';
        return false;
    }
    //构造文件名字:类型_年月日+随机字符串.$ext
    $fullname = strstr($file['type'], '/', TRUE) . '_' . date('Ymd');
    //产生随机字符串
    for ($i = 0; $i < 4; $i++) {
        $fullname .= chr(mt_rand(65, 90));
    }
    //拼凑后缀
    $fullname .= '.' . $ext;
    // 移动到指定目录D
    if (!is_uploaded_file($file['tmp_name'])) {
        // 文件不是上传的
        $error = '错误:不是上传文件!';
    }
    if (move_uploaded_file($file['tmp_name'], $path . $fullname)) {
        // 成功
        return $fullname;
    } else {
        $error = '文件上传错误!';
        return false;
    }
}

使用如下

//使用封装好的函数
$file = $_FILES['image'];
$path = 'uploaded/';
$allow_type = array('image/jpg', 'image/jpeg', 'image/gif');
$allow_format = array('jpg', 'jpeg', 'gif');
$max_size = 8000000;
if ($filename = upload_single($file, $allow_type, $path, $error, $allow_format, $max_size)) {
    echo $filename;
} else {
    echo $error;
}

主页还要更多php教程和原生js开发游戏教程,适合新手小白学习使用

  • 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
发出的红包

打赏作者

恋风.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值