国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

前端h5文件切片上傳,后臺php接收切片并合并

whinc / 2192人閱讀

摘要:網上很多文件切片上傳的文章看了很多最終自己總結了下主要思路如下需要實現的功能前端多文件上傳前端文件切片并命名文件同步上傳切片同步上傳后端接受切片并根據文件名稱保存至文件夾后端判斷是否是最后一個切片合并切片用到的技術文件切片切片上傳請求參數

網上很多文件切片上傳的文章, 看了很多, 最終自己總結了下, 主要思路如下:

1. 需要實現的功能

前端多文件上傳

前端文件切片, 并命名uuid

文件同步上傳, 切片同步上傳

后端接受切片并根據文件名稱保存至文件夾

后端判斷是否是最后一個切片,合并切片

2.用到的技術

h5文件切片

切片上傳請求參數:

filename: file-5bad6aab-cf7d-bfdb-356a-36d7b4ab1e1e.jpg
fragname: frag-1e0d1311-2369-317b-262e-04a9f427ea8c
file: (binary)
fragindex: 0
total: 2

es6 async await

php monolog composer包

3. 開始寫代碼 3.1 前端

html:


點擊上傳, 獲取所有的文件,并處理文件

 $("#upload").click(function () {
            var file = document.getElementById("file");
            //獲取所有文件
            var fileList = file.files;

            //操作文件
            handleFiles(fileList);

            return false;
        });

處理文件方法:
文件上傳同步,上傳文件

async function handleFiles(fileList) {
            var i = 0;
            while (i

處理上傳文件切片,并上傳

//upload file
        async function uploadFile(targetFile,index) {
            //console.log(targetFile);
            var tmp = targetFile.name.split(".");
            var filename = "file-"+guid() + "." + tmp[tmp.length-1] ;
            var fileSize = targetFile.size;
            var total =  Math.ceil( fileSize / pieceSize );

            await handle();

            async function handle() {
                var i = 0;
                var start = end = 0;
                while(i < total){
                    end = start + pieceSize;

                    if(end >= fileSize){
                        end = fileSize;
                    }

                    console.log( "文件的index:" + index+ "| 處理文件切片 i:"+i , "start:" + start,  "end:" + end );
                    var frag = targetFile.slice(start, end);

                    await send( filename,frag,i , total ,function () {
                        console.log( "文件的index:" + index+ "| 切片上傳完成 回調 res111",i)
                    });
                    start = end;
                    i++;
                }
            }
        }

        //send
        async function send(filename,frag,index,total,cb) {

            var formData = new FormData();
            var fragname = "frag-" + guid();

            formData.append("filename",filename);
            formData.append("fragname",fragname);
            formData.append("file",frag);
            formData.append("fragindex",index);
            formData.append("total",total);

            await $.ajax({
                url: url,
                type: "POST",
                cache: false,
                data: formData,
                processData: false,
                contentType: false
            }).done(function (res) {
                //console.log("res:" + index);
                cb && cb();
            }).fail(function (res) {
            });
        }
3.2 后臺php
pushHandler(new StreamHandler(__DIR__."/my_app.log", Logger::DEBUG));

$file = $_FILES["file"];

//打印文件
$log->info("切片",$file);

$orgFileName = $_POST["filename"];
$log->info("orgFileName:" . $orgFileName);

//獲取文件名稱
$filename = explode("." , $_POST["filename"]);

//獲取文件后綴
$ext = $filename[1];
$filename = $filename[0];

$log->info("ext:" . $ext);

//新建frag 文件夾, 以filename為命名方式
if(!file_exists(FRAGPATH.$filename)){
    mkdir(FRAGPATH.$filename);
}

//將接收到的frag文件移入file文件夾中
//$frag_path = SITE_ROOT."/dir/".$filename."/".iconv("UTF-8","gbk",basename($_FILES["file"]["tmp_name"]));
$frag_path = FRAGPATH.$filename ."/". $_POST["fragname"];
try{
    if(move_uploaded_file($_FILES["file"]["tmp_name"] , $frag_path)){
        echo response(["status" => "上傳成功"]);
    }
}catch (Exception $e){
    throw new Exception();
}

//合并file文件夾中的frag為最終文件
if( $_POST["fragindex"] == $_POST["total"] -1 ){
    $blob = "";
    $fragDir = FRAGPATH.$filename;

    $handler = @opendir($fragDir);

    //獲取filename
    while ( ( $fragFileName = readdir($handler) ) !== false ){
        $fp = fopen( FILEPATH . "/" . $orgFileName,"ab" );
        // 務必使用!==,防止目錄下出現類似文件名“0”等情況
        if ($fragFileName !== "." && $fragFileName !== "..")
        {
            //方式一:
            //$blob .= file_get_contents( $fragDir . "/" . $fragFileName );

            //方式二:
            $value = $fragDir . "/" . $fragFileName;
            $handle = fopen($value,"rb");
            fwrite($fp,fread($handle,filesize($value)));
            fclose($handle);

            //刪除切片文件
            @unlink($fragDir . "/" . $fragFileName);
        }
    }

    //合并切片到文件
    //file_put_contents( FILEPATH. "/" . $filename . ".". $ext , $blob );

    //刪除切片文件夾
    @rmdir($fragDir);
}

最終文件上傳成功刪除切片文件夾下的切片

完整代碼地址:https://github.com/lilili001/...

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/29610.html

相關文章

  • Node+H5實現大文件分片上傳(有源碼)

    摘要:話前上傳大文件上傳的教程網上很多但是大部分沒給出一個比較完整的出來這個博客給出的是前后端一套完整的解決方案其中前端沒有使用第三方上傳庫希望能幫到有同樣需求的朋友們大文件分片上傳的好處在這里就不用多說了之前不管是上傳單文件還是分片文件上傳都是 話前 上傳大文件上傳的教程網上很多, 但是大部分沒給出一個比較完整的出來, 這個博客給出的是前后端一套完整的解決方案, 其中前端沒有使用第三方上傳...

    1treeS 評論0 收藏0
  • 關于大文件上傳

    showImg(https://segmentfault.com/img/bVbs1lu?w=675&h=221); 關于大文件上傳 思路 使用js讀取form表單中選擇的file,計算文件md5值,并上傳md5值到服務端,檢查文件是否已上傳過(類似秒傳功能) 若文件未上傳過,按照其大小切成1MB大小的塊,小于1MB的不用切 用ajax異步提交切好的塊上傳至服務端(一個塊一個請求,不阻塞,多線程...

    shusen 評論0 收藏0
  • 關于大文件上傳

    showImg(https://segmentfault.com/img/bVbs1lu?w=675&h=221); 關于大文件上傳 思路 使用js讀取form表單中選擇的file,計算文件md5值,并上傳md5值到服務端,檢查文件是否已上傳過(類似秒傳功能) 若文件未上傳過,按照其大小切成1MB大小的塊,小于1MB的不用切 用ajax異步提交切好的塊上傳至服務端(一個塊一個請求,不阻塞,多線程...

    zollero 評論0 收藏0
  • js實現文件切片上傳,斷點續傳

    摘要:思路很簡單,拿到文件,保存文件唯一性標識,切割文件,分段上傳,每次上傳一段,根據唯一性標識判斷文件上傳進度,直到文件的全部片段上傳完畢。 思路很簡單,拿到文件,保存文件唯一性標識,切割文件,分段上傳,每次上傳一段,根據唯一性標識判斷文件上傳進度,直到文件的全部片段上傳完畢。 以下文字沒有完整的代碼,只有基礎理論,伸手黨繞道。 讀取文件 var input = document.quer...

    widuu 評論0 收藏0

發表評論

0條評論

whinc

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<