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

  • 苹果手机发短信怎么选择卡1卡2(苹果手机发短信怎么切换主副卡)

    苹果手机发短信怎么选择卡1卡2(苹果手机发短信怎么切换主副卡)

  • 华为p40pro有仿真键盘的吗(高仿p40pro)

    华为p40pro有仿真键盘的吗(高仿p40pro)

  • 华为p40自带手机膜的吗(华为p40自带手机壳怎么样)

    华为p40自带手机膜的吗(华为p40自带手机壳怎么样)

  • 固态硬盘读取写入速度多少正常(固态硬盘读取写入速度重要吗)

    固态硬盘读取写入速度多少正常(固态硬盘读取写入速度重要吗)

  • 如何取消京东plus会员(如何取消京东plus会员自动续费)

    如何取消京东plus会员(如何取消京东plus会员自动续费)

  • 未安装的应用如何删除(未安装的应用如何删除vivo手机)

    未安装的应用如何删除(未安装的应用如何删除vivo手机)

  • 手机被暂停服务是怎么回事(手机被暂停服务怎么解决)

    手机被暂停服务是怎么回事(手机被暂停服务怎么解决)

  • 为什么电脑连网显示无internet(为什么电脑连网老是断开?)

    为什么电脑连网显示无internet(为什么电脑连网老是断开?)

  • vivo带nfc功能的手机有哪些(vivo带nfc功能的新款手机)

    vivo带nfc功能的手机有哪些(vivo带nfc功能的新款手机)

  • 苹果手机发微信语音对方听到是噪音(苹果手机发微信怎么换行打字)

    苹果手机发微信语音对方听到是噪音(苹果手机发微信怎么换行打字)

  • 协调控制系统运行方式(协调控制系统运行过程)

    协调控制系统运行方式(协调控制系统运行过程)

  • 海康全彩摄像头补光灯怎么关闭(海康全彩摄像头怎么关闭灯光)

    海康全彩摄像头补光灯怎么关闭(海康全彩摄像头怎么关闭灯光)

  • 低蓝光模式需要开启吗(低蓝光模式需要开吗)

    低蓝光模式需要开启吗(低蓝光模式需要开吗)

  • 电脑doc文件用什么软件打开(电脑word文档用什么软件)

    电脑doc文件用什么软件打开(电脑word文档用什么软件)

  • 手机屏蔽是什么意思(手机屏蔽是什么反应)

    手机屏蔽是什么意思(手机屏蔽是什么反应)

  • word2003页面背景在哪(word2003页面背景在哪里)

    word2003页面背景在哪(word2003页面背景在哪里)

  • iphonexsmax是几核(苹果xsmax处理器是高通吗)

    iphonexsmax是几核(苹果xsmax处理器是高通吗)

  • word如何添加占位符(word中怎么添加)

    word如何添加占位符(word中怎么添加)

  • wps中替换在哪(wps里的替换在哪)

    wps中替换在哪(wps里的替换在哪)

  • 与大数据密切相关的技术是(大数据密切相关的技术是什么)

    与大数据密切相关的技术是(大数据密切相关的技术是什么)

  • 苹果面容识别用不了(苹果面容识别用不了修一下多少钱)

    苹果面容识别用不了(苹果面容识别用不了修一下多少钱)

  • 红米note7和7pro区别(红米note7和7pro区别外观)

    红米note7和7pro区别(红米note7和7pro区别外观)

  • 全民K歌怎么设置相册管理(全民k歌怎么设置音效最好)

    全民K歌怎么设置相册管理(全民k歌怎么设置音效最好)

  • iMessage提示对方尚未开通iMessage解决方法(给对方发短信显示imessage)

    iMessage提示对方尚未开通iMessage解决方法(给对方发短信显示imessage)

  • La Pertusa教堂,西班牙莱里达 (© bbsferrari/Getty Images)(laslajas大教堂)

    La Pertusa教堂,西班牙莱里达 (© bbsferrari/Getty Images)(laslajas大教堂)

  • 非税收入票据能否税前扣除
  • 款已付未收到发票怎么开
  • 公司出售固定资产
  • 过桥过闸通行费会计分录
  • 多开的增值税发票交多少税
  • 债务重组损益的计算公式
  • 出售在建工程要交什么税
  • 承兑汇票兑现怎么填写
  • 股东转入投资款
  • 行政单位的财务报告包括财务报表和财务情况说明书
  • 企业筹建期间需要招几个会计
  • 不动产证上宗地图名字错一个字
  • 未达起征点可以开增值税专票吗
  • 初级如何备考
  • 生产型企业进出口初申报流程
  • 技术服务费增值税可以抵扣吗
  • 房屋维修基金怎么申请使用
  • 微软输入法打不出汉字只有拼音
  • mac如何强制退出全屏
  • linux命令-a
  • php如何使用session
  • 建筑行业企业所得税怎么征收
  • php语言之mysql操作
  • 进货折扣是怎么计算
  • 利息收入结转时怎么做账
  • mcappins.exe - mcappins进程是什么文件 什么意思.
  • 计提坏账准备和转销坏账准备
  • 开票收款人在哪里设置
  • 微前端Qiankun
  • php中exec
  • 深度测试软件
  • mac配置flutter环境变量
  • xss攻击解决方案
  • 计提票面利息
  • 贸易企业开发下游业务
  • 预计负债的主要账务处理
  • 捐款 企业
  • 金税盘已作废发票可以取消吗
  • 进项税通俗易懂
  • SQL Server 2008 R2 应用及多服务器管理
  • 报表中的存货是什么
  • 企业所得税的计提
  • 存货报废进项税转出分录
  • 管理费用包括哪些部门
  • 差额发票如何做账
  • 银行回单中包含哪些内容
  • 累计折旧的借贷方表示
  • 一般纳税人怎样开3个点的专票
  • 权益净利率计算公式产权比率
  • 运费账务怎么处理
  • 影响折旧的因素有哪三个方面
  • 差额清算系统与全额清算系统的区别
  • mysql数据库的介绍
  • winXP系统还能用吗
  • win7系统设置自动关机
  • win7如何设置共享
  • 在microsoft store
  • linux临时目录一般存在哪个文件夹
  • ssd固态硬盘内部结构图
  • xp系统硬盘管理
  • ubuntu怎么建立文件
  • win8系统怎么安装win10
  • Ubuntu系统怎么设置IP
  • win7禁用administrator
  • 打开应用通知栏
  • nodejs操作sqlserver
  • 如何使用ai软件
  • 快速掌握日语词汇
  • linux shell -s
  • python递归函数详解
  • nodejs-websocket
  • Android开发工具
  • eclipse显示错误提示
  • Android的AdapterView及其子类简介-android学习之旅(二十三)
  • 江苏地税电子税务局官网登录
  • 惠州市国家税务局张新华简历
  • 租房减免税收
  • 12345市民热线什么时候有的
  • 服务礼仪包括哪三点
  • 贵州地税电话
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设