位置: IT常识 - 正文

前端将base64图片转换成file文件

编辑:rootadmin
前端将base64图片转换成file文件 1、base64转成file具体代码 // base64图片转file的方法(base64图片, 设置生成file的文件名) function base64ToFile(base64, fileName) { // 将base64按照 , 进行分割 将前缀 与后续内容分隔开 let data = base64.split(','); // 利用正则表达式 从前缀中获取图片的类型信息(image/png、image/jpeg、image/webp等) let type = data[0].match(/:(.*?);/)[1]; // 从图片的类型信息中 获取具体的文件格式后缀(png、jpeg、webp) let suffix = type.split('/')[1]; // 使用atob()对base64数据进行解码 结果是一个文件数据流 以字符串的格式输出 const bstr = window.atob(data[1]); // 获取解码结果字符串的长度 let n = bstr.length // 根据解码结果字符串的长度创建一个等长的整形数字数组 // 但在创建时 所有元素初始值都为 0 const u8arr = new Uint8Array(n) // 将整形数组的每个元素填充为解码结果字符串对应位置字符的UTF-16 编码单元 while (n--) { // charCodeAt():获取给定索引处字符对应的 UTF-16 代码单元 u8arr[n] = bstr.charCodeAt(n) } // 利用构造函数创建File文件对象 // new File(bits, name, options) const file = new File([u8arr], `${fileName}.${suffix}`, { type: type }) // 将File文件对象返回给方法的调用者 return file; }// 调用方法 此时的base64是初始file转换的const file = base64ToFile(base64,'base64转file生成的文件')console.log('base64转回file的---',file);// 将转换后获得的file文件显示在页面的img元素上document.querySelector('#img').src = window.webkitURL.createObjectURL(file)文件转换过程:

推荐整理分享前端将base64图片转换成file文件,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

2、代码解析

​ 该方法涉及知识点较多,首先因为base64的前缀信息部分与文件内容部分是通过,进行连接的,data:image/***;base64(前缀信息),xxxxx(文件内容),所以利用split()方法对base64进行分割,将前缀文件信息,与文件内容分隔开。得到文件前缀信息后,我们就可以利用string.match()方法结合正则表达式,从前缀中获取到文件的类型信息(image/png、image/jpeg、image/webp)以及具体的格式后缀(png、jpeg、webp),保存这些信息,在创建file文件时使用。

​ 接下来我们要对文件内容部分进行处理,借助window.atob()方法对base64文件数据进行解码,获取原来的文件数据流信息,但是以字符串的格式输出。然后利用new Uint8Array(length)创建一个与文件数据流字符串长度相同的8位无符号的整型数字数组,通过该方法创建的整形数组,所有元素初始值都为0。再通过while循环将刚才创建的整形数组中的元素,按照索引替换成文件数据流字串符中对应位置上字符的 UTF-16 代码单元,string.charCodeAt(index)可以获取字符串对应index位置字符的 UTF-16 代码单元,值是位于0~65535之间的整数数字。

​ 最后我们通过File(bits, name, options)构造函数,传入对应的参数创建一个新的file对象后,返回给方法的调用者。至此,完成了base64到file文件的转换。

3、base64

​ 一个完整的base64图片,包含两部分信息的,一部分是文件前缀信息,一部分是表示文件内容信息,例如:data:image/***(表示文件的类型);base64(表示格式),xxxxx(表示文件内容)。我们在base64转换为file的过程中,只需要对文件内容信息进行转换即可,但转换后的file文件类型属性,需要通过文件前缀信息来决定。

红线标注部分为文件前缀信息,其余部分为文件内容:

4、window.atob()和window.btoa()

​ window.btoa()方法可以将一个二进制字符串进行编码为base64编码的ASCII 字符串。我们可以使用这个方法对可能遇到通信问题的字符串进行编码处理,但是有一点要注意:该方法不能对中文字符进行编码处理,只能对英文字母、英文符号和数字进行编码处理。

​ window.atob()方法可以对经过base64编码的字符串进行解码处理,可以将window.btoa()编码后的数据,进行还原;也可以将bsae64格式的文件,解码成原本的文件数据流信息。

前端将base64图片转换成file文件

注: window.atob()和window.btoa()兼容IE9以上浏览器。

如果想要实现对中文字符的编码和解码处理,则需要结合encodeURIComponent()和decodeURIComponent()方法:

编码的过程: 中文字符 —> 先encodeURI —> 再btoa编码 解码的过程: 先atob解码 —> 再decodeURI —> 中文字符

5、File()

​ File(bits, name[, options])方法是File对象的构造函数,拥有两个必填参数和一个可选参数:

​ 第一个参数bits(必填),表示文件的内容,可以是包含ArrayBuffer,ArrayBufferView,Blob,或者 DOMString 对象的 Array ,以及任何这些对象的组合;

​ 第二个参数name(必填),表示创建的file对象的name属性,也就是文件的名字。

​ 第三个参数是options(可选),是一个对象格式的参数,表示文件的可选属性,可选属性有两条:① type:字符串数据,表示文件的类型(image/png、image/jpeg、image/webp等),默认值为""。 ② lastModified:数值型数据,表示文件最后修改时间的Unix时间戳,默认值为Data.now()。

6、相关文档

前端FileReader对象实现图片file文件转base64

Base64

atob()

Uint8Array

match()

chartCodeAt()

File()

本文链接地址:https://www.jiuchutong.com/zhishi/297421.html 转载请保留说明!

上一篇:手拉手教您Linux搭建web(linuxulator)

下一篇:在Vue中获取DOM元素的实际宽高(在vue中获取dom元素)

  • uwp版是什么意思(uwp应用是什么语言开发的)

    uwp版是什么意思(uwp应用是什么语言开发的)

  • ios14本地网络什么意思(下花园6路公交车时间表)

    ios14本地网络什么意思(下花园6路公交车时间表)

  • 京东退货上门取件会要多久(京东退货上门取件收费吗)

    京东退货上门取件会要多久(京东退货上门取件收费吗)

  • 充电瓶怎么知道充满(电瓶怎么看充没充满)

    充电瓶怎么知道充满(电瓶怎么看充没充满)

  • pencil连接ipad失败(pencil连接不上ipd)

    pencil连接ipad失败(pencil连接不上ipd)

  • 表格字怎么分两行

    表格字怎么分两行

  • 小米优化怎么关(怎么关闭小米优化功能)

    小米优化怎么关(怎么关闭小米优化功能)

  • 荣耀30出厂贴膜了吗(荣耀30出厂贴的膜是什么膜)

    荣耀30出厂贴膜了吗(荣耀30出厂贴的膜是什么膜)

  • 小米一直开机关机循环(小米一直不停开关机)

    小米一直开机关机循环(小米一直不停开关机)

  • 小米usbc和typec一样吗(小米usb c和type c区别)

    小米usbc和typec一样吗(小米usb c和type c区别)

  • 苹果需要清理后台吗(苹果需要清理后盖吗)

    苹果需要清理后台吗(苹果需要清理后盖吗)

  • 华为手机怎么删除应用(华为手机怎么删除多余的桌面)

    华为手机怎么删除应用(华为手机怎么删除多余的桌面)

  • 华为手机怎么延长屏保时间(华为手机怎么延时拍照)

    华为手机怎么延长屏保时间(华为手机怎么延时拍照)

  • ipad air3屏幕刷新率(ipadair3屏幕刷新率能调吗)

    ipad air3屏幕刷新率(ipadair3屏幕刷新率能调吗)

  • 荣耀20s支持红外吗(荣耀20s红外功能在设置哪里)

    荣耀20s支持红外吗(荣耀20s红外功能在设置哪里)

  • 高德地图没声音在哪里可以设置(比亚迪高德地图没声音)

    高德地图没声音在哪里可以设置(比亚迪高德地图没声音)

  • 怎样停止手机后台运行

    怎样停止手机后台运行

  • 没加好友可以发文件吗(没加好友可以发红包吗)

    没加好友可以发文件吗(没加好友可以发红包吗)

  • 小米10和小米10pro都是曲面屏吗(小米10和小米10pro钢化膜通用吗)

    小米10和小米10pro都是曲面屏吗(小米10和小米10pro钢化膜通用吗)

  • 处理器的速度用什么来表述(处理器的速度用什么测量)

    处理器的速度用什么来表述(处理器的速度用什么测量)

  • 支付宝预授权在哪里看(支付宝预授权是直接扣款吗)

    支付宝预授权在哪里看(支付宝预授权是直接扣款吗)

  • 手机流量tb是什么意思(流量tb等于多少mb)

    手机流量tb是什么意思(流量tb等于多少mb)

  • 手机wps怎么粘贴照片(手机wps怎么粘贴照片上去)

    手机wps怎么粘贴照片(手机wps怎么粘贴照片上去)

  • 怎么在ios上下载哔咔(怎么在ios上下载不了软件)

    怎么在ios上下载哔咔(怎么在ios上下载不了软件)

  • oppo左上角hd是什么(oppo手机左上角hd)

    oppo左上角hd是什么(oppo手机左上角hd)

  • 苹果手机vue怎么添加自己的音乐(苹果vue怎么清理缓存)

    苹果手机vue怎么添加自己的音乐(苹果vue怎么清理缓存)

  • iphone11pro发售时间(苹果11pro发售)

    iphone11pro发售时间(苹果11pro发售)

  • 没有独立核算的分公司需要报税
  • 代建费用在哪里列支
  • 减免税款的会计分录摘要
  • 存货盘亏计入哪个会计科目
  • 银行理财算投资吗
  • 印花税2021年需要计提吗
  • 非独生子女赡养老人专项附加扣除的标准
  • 在建工程转固定资产凭证附件
  • 收到第三方利息会计分录
  • 短期投资款取消退回计入什么科目?
  • 收到客户银行按时到账
  • 营改增退税政策
  • 营改增后预交营业税怎么处理
  • 违规费用处理
  • 专用发票扣税
  • 小规模与一般纳税人哪个好
  • 资本公积转增股本会计处理
  • 金蝶怎么打开以前的年度账
  • 存货跌价准备用账面余额还是账面价值
  • 返聘人员如何缴纳个人所得税
  • 生产企业成本会计科目
  • 三星笔记本预装系统
  • 票据权利消灭是啥意思
  • windows11怎么添加打印机驱动
  • 公司专柜样品如何做
  • msxct.exe - msxct是什么进程 有什么用
  • php的数组函数
  • 错账缴回的银行会计分录
  • php制作数字验证码
  • 销售返利的形式有哪些
  • 原材料科目是什么意思
  • 残疾人取得房屋所有权
  • yii2框架结构
  • laypage分页
  • php开发过程遇到的难题
  • php调用外部程序
  • 结转工资费用
  • vue设置宽度
  • 蓝色龙舌兰花语
  • [Vue]Vue3学习笔记(尚硅谷)
  • HTML常用标记
  • ChatGPT火爆来袭,携手参与为开源助力
  • 资产处置损益怎么结转到本年利润
  • 运输公司开具的增值税专用发票谁抵扣
  • 客户多付的货款计哪里
  • 什么时候计提所得税费用会计分录
  • 六税两费减半征收政策
  • 土地增值税采用
  • c#连接access数据库实例
  • 采购人员费用计入什么科目
  • 赠送给客户的商品是否要计入费用?
  • 公司设计费会计分录
  • 短期偿债能力是企业的任何利益关系人都
  • 税款减免怎么做分录
  • 房地产竣工验收后结转收入和成本
  • 试算不平衡的原因是什么
  • 固定资产房屋拆除后如何做帐务处理
  • 工资表里有什么
  • 所得税费用会计科目编码
  • 本年利润借方余额需要结转吗
  • 如何更换会计账号
  • mysql数据库输入汉字是问号
  • linux open o_direct
  • windows8怎么更新到最新版本
  • linux who am i
  • windows7开机
  • win7旗舰版系统激活密钥
  • 如何使用朋友的山姆卡
  • rgb与yuv哪个好
  • unity监视器
  • js中的表达式是什么
  • shell脚本 \r
  • python 数据结构库
  • js中文本框设置的代码
  • 禁用javascript后果
  • js上传文件到后端
  • python中操作PDF的库
  • mac解析域名
  • 发票怎能打印
  • 现在买新车都需要交什么费用
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设