base64 转换成file并上传到服务器上

2,base64 转换成file并上传到服务器上

为什么要把base64转换成file在上传呢?原因很简单,就是base64 太大的话,上传太慢了。


// 把base64 转换成文件对象
function dataURLtoFile(base64Str, fileName) {
    var arr = base64Str.split(','),
    mime = arr[0].match(/:(.*?);/)[1], //base64解析出来的图片类型
    bstr = atob(arr[1]), //对base64串进行操作,去掉url头,并转换为byte   atob为window内置方法
    len = bstr.length,
    ab = new ArrayBuffer(len), //将ASCII码小于0的转换为大于0
    u8arr = new Uint8Array(ab); //
    while (len--) {
        u8arr[len] = bstr.charCodeAt(len)
    };
    // 创建新的 File 对象实例[utf-8内容,文件名称或者路径,[可选参数,type:文件中的内容mime类型]]
    return new File([u8arr], fileName, {
        type: mime
     })
};



/**
* 文件上传,异步
*/
function uploadfile(file, callback) {
    var formFile = new FormData();
        formFile.append('file', file);
        $.ajax({
        type: "POST",
        url: _urlIndex + "/file/upload",
        data: formFile,
        dataType: "json",
        cache: false,
        contentType: false, //不设置内容类型
        processData: false, //不处理数据
        success: function (res) {
        callback(res)
        },
        error: function () {
        showMsg('上传失败')
        }
    })
};



// 实际用法


// 把canvasbase64图片转换成文件对象,并上传到服务器
var myfile = dataURLtoFile(image.src, Date.now() + '.png');
uploadfile(myfile, function (res) {
        if (res.code == 0) {
            $("#loadingBox").fadeOut();
        } else {
             showMsg(res.msg)
        }
    })




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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值