pupload 文件分块 php,基于Plupload实现Base64分割的文件上传方案

标题:基于Plupload实现Base64分割的文件上传方案

关键词:文件上传、Base64、Plupload、Blob、分割上传

领域:Web前端

作者:孙振强

日期:2018-04-13

目录

背景

存在问题

2.1. 体积增加1/3

2.2. 大文件上传不稳定

方案思路

3.1. 将服务器端的上传限制调整至足够大。

3.2. 将Base64进行分段传输。

3.3. 将Base64转换回file对象,调用plupload进行上传。

具体实现

4.1. 将Base64文件转化为Blob对象

4.3. 调用plupload将file对象上传

参考资料

5.1. Base64转化为Blob,转化为File的参考文档

5.2. Plupload官方文档

5.3. Plupload中文文档

1. 背景

前端在进行图片上传的时候,有时候会有裁剪的需求,对于裁剪功能现在采用HTML5的canvas实现,处理后的图片为Base64格式,然后将将Base64内容直接提交给后端接口。

除此之外,普通上传采用统一的文件微服务,前端使用plupload插件进行文件的分割、进度、回调等,后端分片接收文件、合并、用fastdfs存储、返回相对路径。

2. 存在问题

背景所述的实现方案在使用的过程存在一定问题:

2.1. 体积增加1/3

Base64化图片后,体积增加1/3左右。

2.2. 大文件上传不稳定

大图片采用Base64单次传输会超过后端接口上传容量设置,并且网络的稳定性也会引起上传的不稳定。

3. 方案思路

重要的问题在2.2.,解决方案可以有以下几种:

3.1. 将服务器端的上传限制调整至足够大。

比如100M,但是这样不够规范和优秀。

3.2. 将Base64进行分段传输。

前端写一个Base64分割传输处理的模块,后端写一个Base64分段接收上传。比较科学,但工作量较大,前后端都需要修改,而且稳定性需要多次优化。

3.3. 将Base64转换回file对象,调用plupload进行上传。

这种方式最理想,因为将变化和工作量都限制在了一个小范围内。

并且plupload是比较完善、成熟的插件,稳定性比较好,后端的实现代码完全不需要修改。

4. 具体实现

本文将详述3.3.方案的具体实现。

4.1. 将Base64文件转化为Blob对象

/**

* Convert a base64 string in a Blob according to the data and contentType.

*

* @param b64Data {String} Pure base64 string without contentType

* @param contentType {String} the content type of the file i.e (image/jpeg - image/png - text/plain)

* @param sliceSize {Int} SliceSize to process the byteCharacters

* @see http://stackoverflow.com/questions/16245767/creating-a-blob-from-a-base64-string-in-javascript

* @return Blob

*/

function b64toBlob(b64Data, contentType, sliceSize) {

contentType = contentType || '';

sliceSize = sliceSize || 512;

var byteCharacters = atob(b64Data);

var byteArrays = [];

for (var offset = 0; offset < byteCharacters.length; offset += sliceSize) {

var slice = byteCharacters.slice(offset, offset + sliceSize);

var byteNumbers = new Array(slice.length);

for (var i = 0; i < slice.length; i++) {

byteNumbers[i] = slice.charCodeAt(i);

}

var byteArray = new Uint8Array(byteNumbers);

byteArrays.push(byteArray);

}

var blob = new Blob(byteArrays, {type: contentType});

return blob;

}

具体转化:

var ImageURL = "";

// Split the base64 string in data and contentType

var block = ImageURL.split(";");

// Get the content type of the image

var contentType = block[0].split(":")[1];// In this case "image/gif"

// get the real base64 content of the file

var realData = block[1].split(",")[1];// In this case "R0lGODlhPQBEAPeoAJosM...."

// Convert it to a blob

var blob = b64toBlob(realData, contentType);

4.2. 将Blob对象转化为File对象

// Convert it to a blob

var blob = b64toBlob(realData, contentType);

// 转为File对象file

val file = new File([blob], "文件名.gif");

//对象信息如下:

//File

// lastModified: 1523531338900

// lastModifiedDate: Date 2018-04-12T11:08:58.900Z

// name: "文件名.gif"

// size: 1951

// type: "image/gif"

// webkitRelativePath: ""

4.3. 调用plupload将file对象上传

下面代码是实例化plupload,使用常规的方法即可,不清楚的同学请查阅5.中的plupload文档。

var uploader = new plupload.Uploader({

runtimes: 'html5,flash,silverlight,html4',

browse_button: 'input_file', //触发文件选择对话框的按钮,为那个元素id

url: upload_url, //服务器端的上传页面地址

chunk_size: '512kb', //割成的大小

max_file_size: '20mb', //最大只能上传1gb的文件

},

init: {

FilesAdded: function (up, files) {

//此处可以做选择文件后的处理

uploader.start();

},

UploadProgress: function () {

//上传过程处理

},

Error: function (up, err) {

$('#input_file').removeAttr('disabled');

if (err.code == '-601') {

$('.error_message').text('请上传图片格式文件!');

} else if (err.code == '-602') {

$('.error_message').text('对不起,此文件刚才已选择上传了。');

} else {

$('.error_message').text('上传文件错误:' + err.code);

}

},

FileUploaded: function (up, file, result) {

//result.response

//上传完成后续处理

}

}

});

下面的代码才是重点,通过plupload进行上传:

//此处uploader为刚才定义的plupload实例,file为base64转化后的对象

uploader.addFile(file);

uploader.start();

大功告成,具体你就来动手实现吧。

5. 参考资料

5.1. Base64转化为Blob,转化为File的参考文档

How to convert a base64 image into a image file and upload it with an asynchronous form using jQuery

5.2. Plupload官方文档

5.3. Plupload中文文档

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值