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