美文网首页php入门教程—打通前后端
php入门教程(十)文件系统

php入门教程(十)文件系统

作者: 党云龙 | 来源:发表于2019-10-24 15:21 被阅读0次

php作为一门服务器语言来说,他的文件管理系统是非常强大的。
所谓文件管理,就是可以在服务器上创建,编辑和复制删除文件。譬如我们新建一个txt文件,我们可以通过php的语法去读写,也可以把路径复制出来提供下载。

但是我们的入门教程更加偏向于应用层,我们这里只讲最常见的功能——文件上传。

如果你想实现譬如说mysql中的数据导出为一个excel之类的操作,应用起来也完全没问题。你只要知道它是通过php的文件管理实现的就行了。

文件上传


比如我们要实现一个用户头像上传的页面:


新建一个测试页面
<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>登陆</title>
        <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/css/bootstrap.min.css">
        <style>
            .login{
                width: 460px;
                border: 1px solid #ccc;
                border-radius: 5px;
                background: #fff;
                margin: 0 auto;
                padding: 10px 20px 20px 20px;
                margin-top: 20px;
            }
            .login h3 {
                margin-top: 10px;
            }
            .login input[type=submit] {
                margin-top: 20px;
                padding: 5px 30px;
            }
            .code {
                display: flex;
            }
        </style>
    </head>
    <body class="bg-info">
        <!--
            注意:表单上传文件必须设置 enctype="multipart/form-data" 否则接收不到信息
        -->
        <form action="doAction.php" method="post" enctype="multipart/form-data">
            <div class="login">
                <input type="hidden" name="MAX_FILE_SIZE" value="1000000">
                <h3>用户信息</h3>
                <div>昵称:<input type="text" name="username" class="form-control"/></div>
                <div>微信:<input type="text" name="weixin" class="form-control"></div>
                <div>头像:<input type="file" name="upfile"></div>
                <input type="submit" class="btn btn-primary" value="确定">
            </div>
        </form>
    </body>
</html>

通过post方式,把file中的值发送到处理页面。

新建一个doaction.php页面,我们对上传的文件做一个验证:

这里注意使用:

$fileInfo = $_FILES["upfile"];

来接收file的值。

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>登陆</title>
    </head>
    <body>
    </body>
</html>
<?php
    $username = $_POST["username"];
    $weixin = $_POST["weixin"];
    $fileInfo = $_FILES["upfile"];
    
    //如果传过来的文件不是空的
    if(!is_null($fileInfo)){
        //如果报错的,先输出错误
        if($fileInfo["error"]>0){
            switch($fileInfo["error"]){
                case 1;
                    echo "上传文件查过了php.ini中upload_max_filesize选项限制的值";
                    break;
                case 2;
                    echo "上传文件的大小超过了HTML表单中 MAX_FILE_SIZE选项指定的值";
                    break;
                case 3;
                    echo "文件只有部分被上传";
                    break;
                case 4;
                    echo "没有文件被上传";
                    break;
                case 6;
                    echo "找不到临时文件夹";
                    break;
                case 7;
                    echo "文件写入失败";
                    break;
            }
            exit;
        }else{
            /*检测文件长度*/
            if($fileInfo["size"]>1000000){
                echo "上传文件大于1M";
                exit;
            }
            /*检测文件扩展名*/
            $allowExt = array("jpeg","jpg","png","gif");
            $ext = strtolower(pathinfo($fileInfo["name"],PATHINFO_EXTENSION));
            if(!in_array($ext,$allowExt)){
                echo "不允许的扩展名!";
                exit;
            }
            /*检测文件类型*/
            $allowMime = array("image/jpeg","image/png","image/gif");
            if(!in_array($fileInfo["type"],$allowMime)){
                echo "上传文件类型错误!";
                exit;
            }
            /*检测是否为真实图片  @getimagesize获取图像信息函数,返回布尔值*/
            if(!@getimagesize($fileInfo["tmp_name"])){
                echo "不是真实图片!";
                exit;
            }
            /*保存图片*/
            $uploadPath = "upload";//储存地址
            if(!file_exists($uploadPath)){
                //如果目录地址不存在就创建这个地址
                $result = mkdir($uploadPath);
            }
            $uniName = md5(uniqid(microtime(true),true));//使用md5创建唯一的名字
            $destination = $uploadPath."/".$uniName.".".$ext;
            
            //检测一下上传完毕的图片是否完整
            if(@move_uploaded_file($fileInfo["tmp_name"],$destination)){
                echo "上传成功!";
                //可以继续操作把文件存如数据库
            }else{
                echo "文件移动失败!";
                exit;
            }
        }
    }else{
        echo "文件上传出错!";
        exit;
    }
?>

上传完毕是这样的:


上传完后,file文件夹中会出现我们上传的文件

其实你可以发现,php上传文件主要是通过:move_uploaded_file方法实现的,只不过在前面我们重新检测了文件类型,大小,后缀名,还通过getimagesize测试了是否为真实图像。
然后呢,对文件重命名,生成文件路径,在通过move_uploaded_file上传到服务器。

我们来看一个稍微复杂的例子:一次上传多个图片。


一次上传多个图片

实现这个的方法也非常的简单:

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>多图片上传</title>
        <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/css/bootstrap.min.css">
        <style>
            .login{
                width: 460px;
                border: 1px solid #ccc;
                border-radius: 5px;
                background: #fff;
                margin: 0 auto;
                padding: 10px 20px 20px 20px;
                margin-top: 20px;
            }
            .login h3 {
                margin-top: 10px;
            }
            .login input[type=submit] {
                margin-top: 20px;
                padding: 5px 30px;
            }
            .code {
                display: flex;
            }
        </style>
    </head>
    <body class="bg-info">
        <!--
            注意:表单上传文件必须设置 enctype="multipart/form-data" 否则接收不到信息
        -->
        <form action="doAction.php" method="post" enctype="multipart/form-data">
            <div class="login">
                <input type="hidden" name="MAX_FILE_SIZE" value="1000000">
                <h3>多图片上传</h3>
                <div>图片1:<input type="file" name="upfile[]"></div>
                <div>图片2:<input type="file" name="upfile[]"></div>
                <div>图片3:<input type="file" name="upfile[]"></div>
                <input type="submit" class="btn btn-primary" value="确定">
            </div>
        </form>
    </body>
</html>

只要把name属性写为:upfile[],已数组的形式提交即可。

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>上传结果</title>
    </head>
    <body>
    </body>
</html>
<?php
    //如果传过来的文件不是空的
    if(!empty($_FILES["upfile"])){
        $file_name = $_FILES["upfile"]["name"];
        $file_tmp_name = $_FILES["upfile"]["tmp_name"];
        for($i=0;$i<count($file_name);$i++){
            if($file_name[$i]!=""){
                $uploadPath = "upload"; //设置上传路径
                if(!file_exists($uploadPath)){
                    //如果没有就创建这个目录
                    $result = mkdir($uploadPath);
                }
                $uniName = md5(uniqid(microtime(true),true));//使用md5创建唯一的名字
                $ext[$i] = strtolower(pathinfo($file_name[$i],PATHINFO_EXTENSION));
                $destination[$i] = $uploadPath."/".$uniName.".".$ext[$i];//生成路径
                move_uploaded_file($file_tmp_name[$i],$destination[$i]);//上传文件
                
                //输出上传名称
                echo "文件".$file_name[$i]."上传成功。更名为".$uniName.".".$ext[$i]."<br/>";
            }
        }
    }
?>
微信截图_20191014085142.png

处理页面在把这个数组给循环开即可!

相关文章

  • php入门教程(十)文件系统

    php作为一门服务器语言来说,他的文件管理系统是非常强大的。所谓文件管理,就是可以在服务器上创建,编辑和复制删除文...

  • PHP采集工具curl快速入门教程

    PHP采集工具curl快速入门教程

  • PHP组件漏洞防护

    内容来源(公众号:PHP基础入门教程)PHP库文件、PHP框架和其他PHP的软件模块,几乎总是以全部权限运行。如果...

  • PHP + Swoole2.0 初体验(swoole入门教程)

    PHP + Swoole2.0 初体验(swoole入门教程) 环境:centos7 + PHP7.1 + swo...

  • MySQL教程

    MySQL 入门教程 MySQL 安装 MySQL 管理 MySQL PHP 语法 MySQL 连接 MySQL ...

  • MySQL教程

    MySQL 入门教程MySQL 安装MySQL 管理MySQL PHP 语法MySQL 连接MySQL 创建数据库...

  • PHP+JS大文件切割异步上传

    用到的PHP文件系统函数 bool move_uploaded_file ( string destination...

  • PHP笔记整理

    PHP入门教程 服务器运行环境配置: ​ 真实运行环境中有: ​ 1.windows 系统 - > windows...

  • 什么是SQL注入漏洞

    内容来源(公众号:PHP基础入门教程)SQL注入漏洞为PHP研发人员所熟知,它是所有漏洞类型中危害最严重的漏洞之一...

  • SQL注入漏洞防护

    内容来源(公众号:PHP基础入门教程)SQL注入是最危险的漏洞之一,但也是最好防护的漏洞之一。本节将介绍在PHP的...

网友评论

    本文标题:php入门教程(十)文件系统

    本文链接:https://www.haomeiwen.com/subject/zffdvctx.html