33 多文件上传及文件下载

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介: 路老师分享PHP语言知识,涵盖多文件上传和文件下载功能。多文件上传只需将表单中的文件域名称改为数组形式,文件下载则通过`header()`函数实现强制下载。详细代码示例和操作步骤,助你轻松掌握PHP核心技术。

有胆量你就来跟着路老师卷起来! -- 纯干货,技术知识分享

路老师给大家分享PHP语言的知识了,旨在想让大家入门PHP,并深入了解PHP语言。

image.gif 编辑


上篇文章简单的了解了介绍实现文件的上传功能及单文件上传案例实现,这次我们继续来了解如何实现多文件上传以及文件的下载功能。

1 多文件上传

PHP支持同时上传多个文件,只需要在表单中对文件上传域使用数组命名即可。单文件上传我们用的是name="upfile",多文件上传只需要把这个改为name="upfile[]"就可以使用了。

<!DOCTYPE html>
<html lang="zh-cn">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>文件上传</title>
    <link rel="stylesheet" href="http://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.css">
</head>
<body class="col-sm-6 col-sm-offset-1 bg-info">
    <h3 class="col-sm-offset-3">多文件上传</h3>
    <form action="mutiDoAction.php" method="post" enctype="multipart/form-data">
        <div class="form-group">
        <label for="exampleInputFile">请选择您要上传的文件</label>
            <input type="file"  id="exampleInputFile" name="upfile[]">
            <p class="text-danger">格式要求:jpeg/png/gif格式</p>
        </div>
        <div class="form-group">
        <label for="exampleInputFile">请选择您要上传的文件</label>
            <input type="file"  id="exampleInputFile" name="upfile[]">
            <p class="text-danger">格式要求:jpeg/png/gif格式</p>
        </div>
        <div class="form-group">
            <label for="exampleInputFile">请选择您要上传的文件</label>
            <input type="file"  id="exampleInputFile" name="upfile[]">
            <p class="text-danger">格式要求:jpeg/png/gif格式</p>
        </div>
        <button type="submit" class="btn btn-info">提交</button>
    </form>
    
</body>
</html>

image.gif

image.gif 编辑

不过,多文件上传的接收action对应的文件需要进行修改,路老师也不吝啬,直接贴出如下:

//mutiDoAction.php
<?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 = 'm_upload';
            if (!file_exists($uploadPath)) {
                $result = mkdir($uploadPath);
            }
            //上传后的文件名要唯一并统一
            $uniName = md5(uniqid(microtime(true), true));
            //获取文件后缀名(文件类型)
            $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>';
        }
    }
}
?>

image.gif

上传成功后的结果如下:

image.gif 编辑

2 文件下载

对于文件下载,通常有两种情况。第一种情况下载浏览器不能解析的文件,如zip压缩文件,这种比较简单,直接使用<a>标签按照如下方式即可实现:

<a href="upload/php.zip">压缩包下载</a>

image.gif

第二种情况,下载浏览器可以解析的文件,如jpg、png图片。使用第一种方法,浏览器可以直接显示图片不会弹出对话框提示用户下载,这就需要使用header()函数来实现文件下载,代码如下:

header('content-disposition:attachment;filename=somefile');

image.gif

header()函数发送原生HTTP头,使用Content-Disposition的报文信息来提供一个推荐的文件名,并且强制浏览器显示一个文件下载的对话框。

具体实现如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>文件下载</title>
</head>
<body>
    <ul>
        <li><a href="upload/php.zip">压缩包下载</a></li>
        <li><a href="upload/列表页.jpg">图片下载</a></li>
        <li><a href="download.php?filename=upload/添加.jpg">图片2下载</a></li>
    </ul>
    
</body>
</html>

image.gif

image.gif 编辑

<?php 
  $filename = $_GET['filename'];
  echo "ss".$filename;
  header('content-disposition:attachment;filename='.basename($filename));
  header('content-length:'.filesize($filename));
  readfile($filename);
?>

image.gif

下载结果如下:

image.gif 编辑

下一篇 PHP 与Ajax 技术

相关文章
|
机器学习/深度学习 数据采集 TensorFlow
使用Python实现智能食品加工优化的深度学习模型
使用Python实现智能食品加工优化的深度学习模型
541 59
|
缓存 监控 前端开发
JavaScript 实现大文件上传的方法
【10月更文挑战第17天】通过以上步骤和方法,我们可以实现较为可靠和高效的大文件上传功能。当然,具体的实现方式还需要根据实际的应用场景和服务器要求进行调整和优化。
|
5月前
|
小程序 安全 JavaScript
构建即时通讯APP内的小程序生态体系:从架构设计到技术实现-优雅草卓伊凡
构建即时通讯APP内的小程序生态体系:从架构设计到技术实现-优雅草卓伊凡
362 1
构建即时通讯APP内的小程序生态体系:从架构设计到技术实现-优雅草卓伊凡
|
XML JSON Java
springboot文件上传,单文件上传和多文件上传,以及数据遍历和回显
本文介绍了在Spring Boot中如何实现文件上传,包括单文件和多文件上传的实现,文件上传的表单页面创建,接收上传文件的Controller层代码编写,以及上传成功后如何在页面上遍历并显示上传的文件。同时,还涉及了`MultipartFile`类的使用和`@RequestPart`注解,以及在`application.properties`中配置文件上传的相关参数。
springboot文件上传,单文件上传和多文件上传,以及数据遍历和回显
|
11月前
|
数据可视化 JavaScript 前端开发
代码可视化平台
这是一个代码可视化工具,旨在简化代码理解过程。用户无需额外配置,直接复制代码即可实时观看执行过程,支持前进后退和动画展示。目前支持JavaScript和Python,未来将扩展更多语言。工具提供了数组、链表、栈、队列、二叉树和哈希表的可视化,并包含辅助函数和自定义注释功能。主要局限在于仅支持单段代码,且执行步数限制为500步。[了解更多](https://staying.fun/zh)
748 20
|
移动开发 数据安全/隐私保护 SEO
(H5自适应)响应式相册图片网站模板 图片壁纸类网站源码下载
1:网站的代码都是纯手工DIV+CSS、代码精简有利于SEO优化。 2:自适应和代码适配两种模式,新版的HTML5技术,给您高端视觉体验。 3:全站每一个细节都做了SEO框架布局,栏目及文章页均可独立设置标题/关键词/描述。 4:附带测试数据、不需安装、上传即用、轻松简单。 5:后台直接修改LOGO、轮播、联系方式、传真、邮箱、地址等,修改更加方便。
458 11
|
12月前
|
开发框架 Cloud Native .NET
C#/.NET/.NET Core技术前沿周刊 | 第 16 期(2024年12.01-12.08)
C#/.NET/.NET Core技术前沿周刊 | 第 16 期(2024年12.01-12.08)
211 6
|
前端开发 API 开发者
React 文件上传组件 File Upload
本文详细介绍了如何在 React 中实现文件上传组件,从基础的文件选择和上传到服务器,再到解决文件大小、类型限制、并发上传等问题,以及实现多文件上传、断点续传和文件预览等高级功能,帮助开发者高效构建可靠的应用。
995 12
|
存储 传感器 监控
什么是 IoT Thingworx
ThingWorx是PTC公司推出的一个快速应用开发平台,专为物联网(IoT)解决方案设计。它通过提供强大的工具和预构建的组件,帮助企业快速构建、部署和管理物联网应用,加速产品上市时间。
1166 11
|
缓存 关系型数据库 MySQL
MySQL执行计划深度解析:如何做出最优选择
【10月更文挑战第23天】 在数据库查询性能优化中,执行计划的选择至关重要。MySQL通过查询优化器来生成执行计划,但有时不同的执行计划会导致性能差异。理解如何选择合适的执行计划,以及为什么某些计划更优,对于数据库管理员和开发者来说是一项必备技能。
771 2