宽容他人,放过自己。

php文件上传

Posted on By anchoriteFili

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 '非法的文件格式';
}

?>
3. 添加upload文件夹

752372-20160623113846078-1281520881.png

752372-20160623113902578-2008405843.png