laravel与vue前后端分离切片上传

4 篇文章 0 订阅
1 篇文章 0 订阅

laravel与vue前后端分离切片上传

  • 后端代码
public function upload(Request $request)
    {
        $file = $request->file('file');
        $realPath = $file->getRealPath(); //临时文件的绝对路径
        $file_size = $request->input('file_size');
        $blob_num = $request->get('blob_num');
        $total_blob_num = $request->get('total_blob_num');
        $file_name = $request->get('file_name');
        $extension = substr($file_name, strripos($file_name, ".") + 1); //文件扩展名
        $array = [
            'mp4', 'mov', 'avi', 'rmvb'
        ];
        if (!in_array($extension, $array)) {
            return response()->json(['code' =>  '403', 'msg' =>  '文件格式不正确']);
        } else {
            // 存储地址
            $path = 'slice/' . date('Ymd');
            $filename = $path . '/' . $file_name . '_' . $blob_num;
            //上传
            $upload = Storage::disk('public')->put($filename, file_get_contents($realPath));
            //判断是否是最后一块,如果是则进行文件合成并且删除文件块
            if ($blob_num == $total_blob_num) {
                for ($i = 1; $i <= $total_blob_num; $i++) {
                    $blob = Storage::disk('public')->get($path . '/' . $file_name . '_' . $i);
                    file_put_contents(public_path('storage') . '/' . $path . '/' . $file_name, $blob, FILE_APPEND);
                }
                //合并完删除文件块
                for ($i = 1; $i <= $total_blob_num; $i++) {
                    Storage::delete('public/' . $path . '/' . $file_name . '_' . $i);
                }
            }
            if ($upload) {
                return response()->json([
                    'code'  =>  '200'
                ]);
            } else {
                return response()->json([
                    'code'  =>  '400'
                ]);
            }
        }
    }
  • 前端代码
<!doctype html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        #progress{
            width: 300px;
            height: 20px;
            background-color:#f7f7f7;
            box-shadow:inset 0 1px 2px rgba(0,0,0,0.1);
            border-radius:4px;
            background-image:linear-gradient(to bottom,#f5f5f5,#f9f9f9);
        }

        #finish{
            background-color: #149bdf;
            background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);
            background-size:40px 40px;
            display: inline-block;
            height: 20px;
        }
        form{
            margin-top: 50px;
        }
    </style>
</head>
<body>
<p id="progress">
    <span id="finish" style="width: 0%;" progress="0"></span>
</p>
<form action="" enctype="multipart/form-data">
    <input type="hidden" name="MAX_FILE_SIZE" value="2000000000">
    <input type="file" name="file" id="file">
    <input type="button" value="停止" id="stop">
</form>
<script>
    var fileForm = document.getElementById("file");
    var stopBtn = document.getElementById('stop');
    var upload = new Upload();

    fileForm.onchange = function(){
        upload.addFileAndSend(this);
    }

    stopBtn.onclick = function(){
        this.value = "停止中";
        upload.stop();
        this.value = "已停止";
    }

    function Upload(){
        var xhr = new XMLHttpRequest();
        var form_data = new FormData();
        const LENGTH = 1024 * 1024 * 5;
        var start = 0;
        var end = start + LENGTH;
        var blob;
        var blob_num = 1;
        var is_stop = 0

        //对外方法,传入文件对象
        this.addFileAndSend = function(that){
            var file = that.files[0];
            blob = cutFile(file);
            sendFile(blob,file);
            blob_num  += 1;
        }

        //停止文件上传
        this.stop = function(){
            xhr.abort();
            is_stop = 1;
        }

        //切割文件
        function cutFile(file){
            var file_blob = file.slice(start,end);
            start = end;
            end = start + LENGTH;
            return file_blob;
        };

        //发送文件
        function sendFile(blob,file){
            var form_data = new FormData();
            var total_blob_num = Math.ceil(file.size / LENGTH);
            form_data.append('file',blob);
            form_data.append('blob_num',blob_num);
            form_data.append('total_blob_num',total_blob_num);
            form_data.append('file_name',file.name);
            form_data.append('file_size',file.size);
            xhr.open('POST','http://www.laravel7.com/api/upload',false);

            xhr.onreadystatechange  = function () {
                if (xhr.readyState==4 && xhr.status==200)
                {
                    console.log(xhr.responseText);
                }

                var progress;
                var progressObj = document.getElementById('finish');
                if(total_blob_num == 1){
                    progress = '100%';
                }else{
                    progress = Math.min(100,(blob_num/total_blob_num)* 100 ) +'%';
                    // console.log(progress);
                    // console.log('分割');
                }
                progressObj.style.width = progress;
                var t = setTimeout(function(){
                    if(start < file.size && is_stop === 0){
                        blob = cutFile(file);
                        sendFile(blob,file);
                        blob_num  += 1;
                    }else{
                        setTimeout(t);
                    }
                },1000);
            }
            xhr.send(form_data);
        }
    }

</script>
</body>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在SpringBoot和Vue的前后分离项目中,实现文件上和回显可以通过以下步骤完成。 首先,前部分需要创建一个文件上的组件,可以使用Vue的axios库来发送文件到后。在组件中,通过input标签的type属性设置为file,用户可以选择要上的文件。然后,通过axios库将文件发送到后的API接口。 在后部分,需要创建一个接收文件上的API接口。可以使用SpringBoot的MultipartFile来接收文件。在接口中,可以对文件进行处理,例如保存到服务器的指定路径下。 接下来,为了实现文件回显,可以在后创建一个API接口,用于获取已上的文件列表。在前部分,可以通过axios库调用该API接口,获取文件列表,并在页面上展示出来。 需要注意的是,前后分离的项目中,前和后是独立的两个部分,需要通过API接口进行通信。因此,在前部分需要配置好API接口的地址,以便正确地发送请求和接收响应。 以上是实现SpringBoot和Vue前后分离文件上和回显的一般步骤。具体的实现细节可以根据项目需求进行调整和扩展。 #### 引用[.reference_title] - *1* *3* [Vue+SpringBoot实现前后分离的文件上](https://blog.csdn.net/oppo5630/article/details/79318715)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Springboot+vue前后分离实现文件上](https://blog.csdn.net/qq_51742972/article/details/123705718)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值