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开发游戏教程,适合新手小白学习使用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

恋风.

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

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

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

打赏作者

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

抵扣说明:

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

余额充值