前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >PHP大文件分块上传功能实例详解

PHP大文件分块上传功能实例详解

作者头像
砸漏
发布2020-10-20 10:34:54
8590
发布2020-10-20 10:34:54
举报
文章被收录于专栏:恩蓝脚本

本文实例讲述了PHP大文件分块上传功能。分享给大家供大家参考,具体如下:

前端代码

使用file.slice将文件进行分割,然后分别进行异步上传。

代码语言:javascript
复制
<!DOCTYPE html 
<html lang="zh-cn" 
 <head 
  <meta charset="utf-8" 
  <meta http-equiv="X-UA-Compatible" content="IE=edge" 
  <meta name="viewport" content="width=device-width, initial-scale=1" 
  <title <%= title % </title 
  <!-- zui -- 
  <link rel="stylesheet" href="http://zui.sexy/dist/css/zui.min.css" rel="external nofollow"  
 </head 
 <body 
  <div class="container" style="margin-top: 30px;" 
    <form class="form-inline" method="post" enctype="multipart/form-data" 
     <div class="form-group" 
      <input type="file" id="fileBig" class="form-control" 
     </div 
     <button type="submit" class="btn btn-primary" 提交</button 
    </form 
  </div 
  <!-- ZUI Javascript 依赖 jQuery -- 
  <script src="http://zui.sexy/assets/jquery.js" </script 
  <!-- ZUI 标准版压缩后的 JavaScript 文件 -- 
  <script src="http://zui.sexy/dist/js/zui.min.js" </script 
  <script type="text/javascript" 
    $('form').submit(function() {
      let file = $(":file")[0].files[0];
      let fileName = file.name;
      let fileSize = file.size;
      console.log('fileSize',fileSize);
      let blockSize = 0.9*1024*1024;
      let num = Math.ceil(fileSize/blockSize);
      let start = 0;
      let end = 0;
      for(let i=1;i<=num;i++){
        end = blockSize*i;
        if(end   fileSize){
          end = fileSize;
        }
        let block = file.slice(start,end);
        start = end;
        let fd = new FormData();
        fd.append('block',block);
        fd.append('name',fileName);
        fd.append('total',num);
        fd.append('index',i);
        $.ajax({
          url:"upload.php",
          type:"POST",
          data:fd,
          async:true,
          processData:false,
          contentType:false,
          success:(res)= {
            console.log('res_'+i+":");
            console.log(res);
          }
        })
      }
      return false;
    });
  </script 
 </body 
</html 

后端代码

在所有的文件上传成功之后,合并生成原来的大文件

代码语言:javascript
复制
<?php
$name = $_POST['name'];
$index = $_POST['index'];
$total = $_POST['total'];
echo "name:".$name.PHP_EOL;
echo "index:".$index.PHP_EOL;
echo "total:".$total.PHP_EOL;
move_uploaded_file($_FILES['block']['tmp_name'],'upload/'.$name."_".$index);
$list = scandir('upload');
$num = count($list)-2;
echo "cur_num:".$num.PHP_EOL;
if($num == $total){
  echo "upload done".PHP_EOL;
  echo $cmd = "cat upload/'{$name}_'*   upload/'{$name}'";
  shell_exec($cmd);
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档