php文件上传
in 知识 on Php
1. 在html中添加上传表
<html>
<head>
<meta charset="utf-8">
<title>include测试</title>
</head>
<body>
<!--
<form>标签的enctype属性规定了在提交表单时要使用哪种内容类型,
在表单需要二进制数据时,比如文件内容,请使用"multipart/form-data"
<input>标签的type="file"属性规定了应该把输入作为文件来处理
注释:允许用户上传文件是一个巨大的阿暖风险。请仅仅允许可信的用户执行文件上传操作
-->
<form action="test.php" method="post" enctype="multipart/form-data">
<label for="file">文件名:</label>
<input type="file" name="file" id="file"><br>
<input type="submit" name="submit" value="提交">
</form>
</body>
</html>
2. 书写php有关代码
<?php
// 上传文件限制
// 允许上传的图片后缀
$allowedExts = array("gif", "jpeg", "jpg", "png");
$temp = explode(".", $_FILES["file"]["name"]);
$extension = end($temp);
if ((($_FILES['file']['type'] == 'image/gif')
|| ($_FILES['file']['type'] == 'image/jpeg')
|| ($_FILES['file']['type'] == 'image/jpg')
|| ($_FILES['file']['type'] == 'image/pjpeg')
|| ($_FILES['file']['type'] == 'image/x-png')
|| ($_FILES['file']['type'] == 'image/png'))
&& ($_FILES['file']['size'] < 204800)
&& in_array($extension, $allowedExts)) {
if ($_FILES['file']['error'] > 0) {
echo "错误:" . $_FILES['file']['error'] . "<br>";
} else {
echo "上传文件名:" . $_FILES["file"]["name"] . "<br>";
echo "上传类型:" . $_FILES["file"]["type"] . "<br>";
echo "文件大小" . ($_FILES["file"]["size"] / 1024) . "kB<br>";
echo "文件临时存储的位置:" . $_FILES["file"]["tmp_name"] . "<br>";
// 判断当前目录下的upload目录是否存在该文件
// 如果没有upload目录,你需要创建它,upload目录权限为777
if (file_exists("upload/" . $_FILES['file']['name'])) {
echo $_FILES['file']['name'] . '文件已存在';
} else {
// 如果upload目录不存在该文件上传到upload目录下
move_uploaded_file($_FILES['file']['tmp_name'], 'upload/' . $_FILES['file']['name']);
echo '文件存储在:' . 'upload/' . $_FILES['file']['name'];
}
}
} else {
echo '非法的文件格式';
}
?>