前端
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>文件操作</title>
</head>
<body>
<h2>文件上传</h2>
<!--文件上传必须是post类似-->
<form action="demo.php" method="post" enctype="multipart/form-data">
<!-- name: 最终会成为php中的$_FILES['my_file']-->
<input type="file" name="my_file">
<button>上传</button>
</form>
</body>
</html>
后端
<?php
//文件上传的原理
// 1. 配置上传参数
$fileType = ['jpg', 'png', 'gif'];
$fileSize = 3145728;
$filePath = '/uploads/';
// 原始文件名
$fileName = $_FILES['my_file']['name'];
// 临时文件名
$tempFile= $_FILES['my_file']['tmp_name'];
//2. 判断是否上传成功?判断是否上传成功
$uploadError = $_FILES['my_file']['error'];
if ($uploadError > 0 ) {
switch ($uploadError) {
case 1:
case 2: die('上传文件过大');
case 3: die('文件上传不完整');
default: die('未知错误');
}
}
// 3. 判断文件扩展名是否支持?
$extension = explode('.', $fileName)[1];
if (!in_array($extension, $fileType)) {
die('不允许上传 ' . $extension . '文件类型');
}
// 4. 生成不可重复的临时文件名
$fileName = date('YmdHis',time()).md5(mt_rand(1,99)). '.' . $extension;
// 5. 文件上传
if (is_uploaded_file($tempFile)) {
if (move_uploaded_file($tempFile, __DIR__ . $filePath . $fileName)) {
echo "上传成功";
} else {
die('上传失败');
}
} else {
die('非法操作');
}
exit;
总结
了解了文件上传的代码该如何写。
文件上传,需要满足预设的条件(类型,大小等),文件会先上传到临时文件地址(检测文件夹是否存在,不存在就创建),然后再将临时文件移动到此磁盘的过程(判断文件使用是否是由post方法提交)。