位置: 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元素)

  • 微信朋友圈背景怎么设置动态视频(微信朋友圈背景图系统维护怎么取消)

    微信朋友圈背景怎么设置动态视频(微信朋友圈背景图系统维护怎么取消)

  • 微信视频怎么转发到QQ(微信视频怎么转发到抖音里面)

    微信视频怎么转发到QQ(微信视频怎么转发到抖音里面)

  • 小米10指纹解锁闪光可以关闭吗(小米10指纹解锁不见了)

    小米10指纹解锁闪光可以关闭吗(小米10指纹解锁不见了)

  • qq资料卡展示在哪里设置(qq资料卡显示设置在哪里)

    qq资料卡展示在哪里设置(qq资料卡显示设置在哪里)

  • 电脑打字的顿号在上面怎样打(电脑打字顿号怎么输入都是斜杠)

    电脑打字的顿号在上面怎样打(电脑打字顿号怎么输入都是斜杠)

  • 微信怎么看红包发了多少(微信怎么看红包记录和转账记录)

    微信怎么看红包发了多少(微信怎么看红包记录和转账记录)

  • mail代表什么(mail是什么意思中文翻译)

    mail代表什么(mail是什么意思中文翻译)

  • 抖音的音浪是每个月清零吗(抖音的音浪每天都可以提现吗)

    抖音的音浪是每个月清零吗(抖音的音浪每天都可以提现吗)

  • 硬盘打开提示需格式化(硬盘打开提示需格式化是什么问题)

    硬盘打开提示需格式化(硬盘打开提示需格式化是什么问题)

  • 苹果已购买的项目隐藏了怎么找出来(苹果已购买的项目怎么退订)

    苹果已购买的项目隐藏了怎么找出来(苹果已购买的项目怎么退订)

  • 如何查看自己的手机有没有被挖矿(如何查看自己的征信是否良好)

    如何查看自己的手机有没有被挖矿(如何查看自己的征信是否良好)

  • 快手曝光和播放的区别(快手曝光和播放量的区别)

    快手曝光和播放的区别(快手曝光和播放量的区别)

  • oppo视频对方听不到声音(oppo视频对方听不见)

    oppo视频对方听不到声音(oppo视频对方听不见)

  • 苹果电子发票可以保修吗(苹果电子发票可以查到序列号吗)

    苹果电子发票可以保修吗(苹果电子发票可以查到序列号吗)

  • 怎么给华为荣耀7x插卡(怎么给华为荣耀5语音助手改名字)

    怎么给华为荣耀7x插卡(怎么给华为荣耀5语音助手改名字)

  • ipad充电为什么超级慢(ipad充电为什么是黄色)

    ipad充电为什么超级慢(ipad充电为什么是黄色)

  • 抖音网址是多少(抖音的网址是什么呢)

    抖音网址是多少(抖音的网址是什么呢)

  • keylock密码锁重置(keylock密码锁重置后总是提示重新操作)

    keylock密码锁重置(keylock密码锁重置后总是提示重新操作)

  • 抖音通讯录怎么设置(抖音通讯录怎么找不到好友)

    抖音通讯录怎么设置(抖音通讯录怎么找不到好友)

  • 苹果无线耳机丢了怎么找回(苹果无线耳机丢了还能找回来吗)

    苹果无线耳机丢了怎么找回(苹果无线耳机丢了还能找回来吗)

  • 抖音72小时仅自己可见怎么取消(抖音1小时限制)

    抖音72小时仅自己可见怎么取消(抖音1小时限制)

  • 小米手环3充不进去电什么情况啊(小米手环3充不上电正确的修复方法)

    小米手环3充不进去电什么情况啊(小米手环3充不上电正确的修复方法)

  • dedecms织梦自动给图片添加alt属性(织梦如何添加浮动广告)

    dedecms织梦自动给图片添加alt属性(织梦如何添加浮动广告)

  • 房产税从价改从租,多缴税款要加收滞纳金吗
  • 小企业外币交易的类型有哪些
  • 企业所得税视同销售的会计处理
  • 其他综合收益是什么类科目
  • 专项资金审计的目的
  • 自产自用的资源税记入
  • 期末存货跌价准备金额的确定
  • 佣金收入者是什么意思
  • 经营租赁是主营业务收入吗
  • 工程施工企业人工成本最高多少
  • 处置交易性金融资产发生的交易费用
  • 废旧物资增值税税收优惠政策
  • 防洪基金怎么做分录
  • 固定资产评估费计入什么会计科目
  • 个体不超过10万怎么交税
  • 城建税计税依据及税率
  • 不征税发票如何开具
  • 出口退税需要什么单据
  • 暂估在建工程会计科目
  • 清华同方笔记本怎么进入u盘启动
  • 收入3000以下占比
  • 企业废业实收资产怎么算
  • linux传输数据
  • macbook怎么设置输入法
  • 老板垫资如何做账务处理
  • 缴纳公积金需要什么
  • 埃热泽尔斯湖面上的波纹,拉脱维亚拉特加尔地区 (© Eaglewood Films/Nimia)
  • 苹果最小的充电器是哪一款
  • 专项储备购买安全设备会计分录
  • 巴黎拉丁区有个著名的人文景点叫做先贤祠
  • vue自定义弹窗带有遮罩层
  • img标签铺满div
  • vuejs props
  • php上传照片
  • 怎样计提购销合同印花税
  • 提供餐饮服务购入农产品的进项税额抵扣问题
  • 留购价计入什么费
  • 进项税发票可以跨年认证吗
  • 现金流量表的附表如何编制
  • 吸收合并的目的是什么
  • 普票专票的销售额怎么理解
  • 帝国cms使用手册
  • python unittest和pytest
  • mysql常见操作
  • java查询mongodb数据
  • 累计盈余的借方
  • 建设工程的材料质量检测由谁负责
  • 个体户开电子发票怎么申请
  • c#调用excel
  • 消防工程改造怎样入账
  • 民间非营利组织会计制度及操作实务
  • 调研费属于什么会计科目
  • 应收账款资金占用费怎么算
  • 企业向个人借款利息如何缴纳增值税
  • 电子汇票接收后怎么操作
  • 收到投资款现金流量
  • 红字发票是干什么的
  • 分支机构属于小型微利企业吗?
  • 财务费用的内容包括哪些
  • java数据类型举例
  • windows102021年更新
  • 苹果电脑安装中国银行网银助手
  • mac使用磁盘工具的快捷键
  • win7怎么设置网速限制
  • windows8.1开始
  • 安装怎么弄
  • win7系统怎么设置屏保
  • win10周年纪念版
  • 用jquery制作网页
  • 简述javascript
  • python生成矩阵的方法
  • js中的原型和原型链
  • jquery的实现原理
  • android系统主要特点
  • 办理税务迁移的流程
  • 增值税报表进项税和销项税都不填可以吗
  • 广东每年交多少税给国家
  • 南通国税电子税务局
  • 国税网查发票真伪
  • 应交税金包含企业所得税吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设