跨境派

跨境派

跨境派,专注跨境行业新闻资讯、跨境电商知识分享!

当前位置:首页 > 工具系统 > 运营工具 > 前端base64转file文件方法

前端base64转file文件方法

时间:2024-04-18 10:00:43 来源:网络cs 作者:淼淼 栏目:运营工具 阅读:

标签: 文件  方法 

前端base64转file文件方法

背景解决办法文章参考

背景

有这样一种场景,比如canvas截取部分dom作为图片,上传到服务器,而canvas截取的图片返回的是base64字符串,而服务器接收的是file文件。因此我们需要将base64字符串转成file文件,存储到服务器中。

解决办法

方法一:通过new File(),将base64直接转成file文件。 (此方法需要考虑浏览器兼容问题)
// 第一个参数dataUrl是一个base64的字符串。第二个参数是文件名可以随意命名function base64toFile(dataurl, filename = 'file') {  let arr = dataurl.split(',');  let mime = arr[0].match(/:(.*?);/)[1];  // suffix是该文件的后缀  let suffix = mime.split('/')[1];  // atob 对经过 base-64 编码的字符串进行解码  let bstr = atob(arr[1]);  // n 是解码后的长度  let n = bstr.length;  // Uint8Array 数组类型表示一个 8 位无符号整型数组 初始值都是 数子0  let u8arr = new Uint8Array(n);  // charCodeAt() 方法可返回指定位置的字符的 Unicode 编码。这个返回值是 0 - 65535 之间的整数  while (n--) {    u8arr[n] = bstr.charCodeAt(n);  }  // new File返回File对象 第一个参数是 ArraryBuffer 或 Bolb 或Arrary 第二个参数是文件名  // 第三个参数是 要放到文件中的内容的 MIME 类型  return new File([u8arr], `${filename}.${suffix}`, {    type: mime,  });}
方法二:先将base64转换成blob,再将blob转换成file文件,此方法不存在浏览器不兼容问题
//1,先将base64转换为blobfunction dataURLtoBlob(dataurl) {  var arr = dataurl.split(','),  mime = arr[0].match(/:(.*?);/)[1],  bstr = atob(arr[1]),  n = bstr.length,  u8arr = new Uint8Array(n);  while (n--) {    u8arr[n] = bstr.charCodeAt(n);  }  return new Blob([u8arr], { type: mime });}//2,再将blob转换为filefunction blobToFile(theBlob, fileName){  theBlob.lastModifiedDate = new Date();  // 文件最后的修改日期  theBlob.name = fileName;                // 文件名  return new File([theBlob], fileName, {type: theBlob.type, lastModified: Date.now()});}// 使用示例function base64toFile(file) {  // 1.先转为 blob格式  file.content是此文件的base64格式   let blob =  this.dataURLtoBlob(file.content);  // 拿到文件名  let fileName = file.file.name;   // 2,在转为 file类型  let file1 = this.blobToFile(blob,fileName);  console.log("file1:",file1);    // 3,上传...}

文章参考

https://blog.csdn.net/qq_43886365/article/details/126729188

本文链接:https://www.kjpai.cn/news/2024-04-18/159959.html,文章来源:网络cs,作者:淼淼,版权归作者所有,如需转载请注明来源和作者,否则将追究法律责任!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。

文章评论