大文附件分片上传

3 篇文章 0 订阅
3 篇文章 0 订阅

 引用脚本下载地址  提取码:t9bp

 

<link href="webuploader-0.1.5/css/uploadify.css" rel="stylesheet" />
<link href="webuploader-0.1.5/css/webuploader.css" rel="stylesheet" />
<script src="webuploader-0.1.5/dist/webuploader.js"></script>
<script src="js/jquery-extend.js"></script>
<script src="js/jquery.unobtrusive-ajax.js"></script>
<script src="js/layer/layer.js"></script>
<script>
$(function () {
            //显示验证信息
            function validateMessage(file, show, message) {
                var $li = $('#' + file.id);
                if (show) {
                    $li.find('.cancel').show();
                } else {
                    $li.find('.cancel').hide();
                }
                $li.find('span.data').text('-' + message);
            };

            //上传文件
            $("#id").click(function () {
                //页面层
                layer.open({
                    type: 1,
                    title: "上传文件",
                    skin: 'layui-layer-rim', //加上边框
                    area: '540px', //宽高
                    content: '<div id="uploader" class="wu-example">' +
                        '<div id="thelist" class="uploader-list" style="min-height: 420px;"></div>' +
                        '<div class="btns" style="display: inline-block;margin: 10px 170px;">' +
                        '<div id="picker" style="display: inline-block;margin-right: 10px;">选择文件</div>' +
                        '<div id="ctlBtn" class="webuploader-pick">开始上传</div>' +
                        '</div>' +
                        '</div>',
                    end: function () {
                        //layer.load();
                        //window.location.reload();
                    }
                });

                var $list = $('#thelist'),
                    $btn = $('#ctlBtn'),
                    state = 'pending',
                    uploader;

                uploader = WebUploader.create({
                    chunked: true,
                    swf: '/Content/webuploader-0.1.5/dist/Uploader.swf',
                    threads: 1,
                    chunkSize: 100000,//每片大小
                    server: '后台请求地址',
                    pick: '#picker'
                });

                // 当有文件添加进来的时候
                uploader.on('fileQueued', function (file) {
                    $list.append('<div id="' + file.id + '" title="' + file.name + '" class="uploadify-queue-item">' +
                        '<div class="cancel" data-id="' + file.id + '">' +
                        '<a href="javascript:">X</a>' +
                        '</div>' +
                        '<span class="fileName">' + $.omit(file.name, 25) + '(约' + $.bytesToSize(file.size) + ')</span>' +
                        '<span class="data"> -  0%</span>' +
                        '<div class="uploadify-progress">' +
                        '<div class="uploadify-progress-bar" style="width: 0%;">' +
                        '</div>' +
                        '</div>' +
                        '</div>');
                });


                //删除文件队列
                $(".uploader-list").on("click", ".cancel[data-id]", function () {
                    var $this = $(this);
                    $('#' + $this.data("id")).remove();
                    uploader.removeFile(uploader.getFile($this.data("id")));
                });

                //每个文件上传是重新生成唯一标识GUID
                uploader.on('uploadStart', function (file) {
                    $('#' + file.id).find('.cancel').hide();
                    uploader.option("formData", { guid: $.NewGuid(), name: file.name });
                });

                //分片上次时,上传每片服务器所响应的数据
                uploader.on('uploadAccept', function (obj, ret) {
                    //服务器已存在该文件
                    if (!ret.code && ret.code === 0) {
                        uploader.cancelFile(obj.file);
                        validateMessage(obj.file, true, "文件已存在");
                    }
                });

                // 文件上传过程中创建进度条实时显示。
                uploader.on('uploadProgress', function (file, percentage) {
                    var $li = $('#' + file.id),
                        $percent = $li.find('.uploadify-progress .uploadify-progress-bar');
                    var $width = percentage * 100;
                    $li.find('span.data').text('-' + $width.toPrecision(3) + '%');
                    $percent.css('width', $width + '%');
                });

                //上传成功
                uploader.on('uploadSuccess', function (file, response) {
                    validateMessage(file, false, response.message)
                });

                //上传错误
                uploader.on('uploadError', function (file) {
                    validateMessage(file, true, "-上传出错");
                });

                //验证错误
                uploader.on('error', function (file) {
                    validateMessage(file, true, "-上传出错");
                });

                $btn.on('click', function () {
                    if (state === 'uploading') {
                        uploader.stop();
                    } else {
                        uploader.upload();
                    }
                });
            });
        });
</script>

 

Spring Boot 和 Vue 是一对非常流行的框架和库,分别用于后端和前端开发。而附件分片上传和下载功能是一种常见的需求。 在后端使用 Spring Boot 可以很方便地实现附件分片上传和下载功能。可以使用 Spring Boot 提供的文件上传功能,结合分片上传的思想,将一个大文件切分为多个小的文件片段进行上传。在前端使用 Vue 可以通过前端传输文件并将文件分片,将文件的每个片段按需发送给后端。 对于分片上传功能,后端可以使用 Spring Boot 的 MultipartResolver 接口接收前端传来的文件片段,并将其保存到临时位置。然后可以根据每个文件片段的顺序和文件唯一标识,将文件片段合并成完整的文件。这里可以使用 Apache Commons FileUpload 或者 Spring Boot 的 MultipartResolver 来实现。 对于分片下载功能,后端可以根据前端传来的文件标识和请求的文件片段进行处理。后端将文件切分为多个片段,然后根据前端传来的片段索引,返回对应的文件片段给前端。前端接收到每个片段后,可以按顺序拼接成完整的文件。 需要注意的是在分片上传和下载过程中,要注意文件的完整性校验和数据一致性问题。可以考虑使用文件的 MD5 值来校验文件的完整性,前端每次上传或下载时,都需要带上文件的 MD5 值进行校验。 总结来说,Spring Boot 和 Vue 可以很好地实现附件分片上传和下载功能。通过合理地切分文件和处理文件片段,可以提高上传和下载的效率和可靠性。 需要注意的是,以上只是一种实现思路,具体的实现方式还需要根据具体的业务需求和技术栈选择适合的工具和库来完成。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值