位置: 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空间活动推广)

    QQ空间推广之引流方法推荐(qq空间活动推广)

  • 苹果11屏幕黑白怎么调回来(苹果11屏幕黑白屏)

    苹果11屏幕黑白怎么调回来(苹果11屏幕黑白屏)

  • 苹果12不送充电器吗(苹果12不送充电线吗)

    苹果12不送充电器吗(苹果12不送充电线吗)

  • 怎么解散qq群(怎么解散QQ群失败)

    怎么解散qq群(怎么解散QQ群失败)

  • OPPO手机如何恢复备份(oppo手机如何恢复删除的照片和视频)

    OPPO手机如何恢复备份(oppo手机如何恢复删除的照片和视频)

  • 键盘无法输入(键盘无法输入任何东西)

    键盘无法输入(键盘无法输入任何东西)

  • 钉钉全员静音是什么意思(钉钉全员静音是什么)

    钉钉全员静音是什么意思(钉钉全员静音是什么)

  • 手机停机还能接电话吗(手机开不了机怎么办)

    手机停机还能接电话吗(手机开不了机怎么办)

  • 32漏电开关带6千瓦行吗(漏电开关32和63)

    32漏电开关带6千瓦行吗(漏电开关32和63)

  • vivoy93s怎么恢复出厂(vivo y3怎样恢复)

    vivoy93s怎么恢复出厂(vivo y3怎样恢复)

  • 扫描件和照片的区别(扫描件和照片的法律效力)

    扫描件和照片的区别(扫描件和照片的法律效力)

  • 华为为什么门禁卡模拟了但是用不了(华为为什么门禁卡模拟了但是读卡失败)

    华为为什么门禁卡模拟了但是用不了(华为为什么门禁卡模拟了但是读卡失败)

  • 小米手环4怎么获取音乐(小米手环4怎么设置密码)

    小米手环4怎么获取音乐(小米手环4怎么设置密码)

  • 拼多多保留5个团啥意思(拼多多保留5个团怎么操作)

    拼多多保留5个团啥意思(拼多多保留5个团怎么操作)

  • ppt显示媒体不可用(ppt里面媒体不可用)

    ppt显示媒体不可用(ppt里面媒体不可用)

  • 手机发热是怎么回事(手机发热是怎么处理)

    手机发热是怎么回事(手机发热是怎么处理)

  • 东莞通怎么用(东莞通app上可以充值吗)

    东莞通怎么用(东莞通app上可以充值吗)

  • 地图实景图怎么用(地图实景图怎么画)

    地图实景图怎么用(地图实景图怎么画)

  • 台湾版xr支持电信吗(台湾版xr和国行xr的区别)

    台湾版xr支持电信吗(台湾版xr和国行xr的区别)

  • 红米手机耳机怎么设置(红米手机耳机插哪)

    红米手机耳机怎么设置(红米手机耳机插哪)

  • iphone x可以遥控空调吗(iphonex可以遥控器)

    iphone x可以遥控空调吗(iphonex可以遥控器)

  • 表格中的小三角怎么弄(表格中的小三角怎么去除)

    表格中的小三角怎么弄(表格中的小三角怎么去除)

  • ftpte.exe是什么进程 有什么作用 ftpte进程查询(ftp指什么)

    ftpte.exe是什么进程 有什么作用 ftpte进程查询(ftp指什么)

  • 长春花怎么养,长春花的养殖方法(长春花怎么养才能爆花)

    长春花怎么养,长春花的养殖方法(长春花怎么养才能爆花)

  • 杜拉通河谷中的Nuestra Señora de la Hoz老修道院,西班牙塞哥维亚 (© Arco Images GmbH/Alamy)

    杜拉通河谷中的Nuestra Señora de la Hoz老修道院,西班牙塞哥维亚 (© Arco Images GmbH/Alamy)

  • 前端原生Html免费模板网站总结(带网址)(前端 原生)

    前端原生Html免费模板网站总结(带网址)(前端 原生)

  • 【Discuz】实现主题标题和正文同时显示

    【Discuz】实现主题标题和正文同时显示

  • 增值税发票综合服务平台红字确认
  • 税收筹划的内容主要包括
  • 个人缴纳职业年金是什么意思
  • 兼职人员账务处理
  • 预付账款和应付账款的区别
  • 坏账核销的会计规定
  • 乙方向甲方开具增值税专用发票
  • 公司收到红字发票怎么开
  • 增值税一般纳税人税率是多少?
  • 计提存货减值准备怎么算
  • 住房公积金的会计处理
  • 搬迁补偿收入计入什么会计科目
  • 股票投资会计科目
  • 小规模纳税人购置税控设备
  • 货样广告品管理办法
  • 劳务外包用工单位可以抵扣进项税吗
  • 购进货物取得
  • 企业每个月都要关账吗
  • 工程改造合同印花税
  • 免税企业收到的专用发票要怎么转出
  • 厂房租赁税率是房东交的吗
  • 异地预缴的税款是抵减全部的税款吗
  • 固定资产清理的借贷方向表示什么
  • 贴现率与再贴现率计算机行业是好多
  • 成品油生产企业身份归类管理办法
  • 定额备用金的账务怎么做
  • 小规模纳税人的专票可以抵税吗
  • wifi上传速度为0的解决方法
  • 企业购地流程
  • php 数字转中文
  • web课程设计网页
  • 企业注销时还有应付职工薪酬怎么办
  • 销售折让怎么开票
  • 知识产权作用
  • 矿产资源补偿费计入科目
  • 微信php开发教程
  • 暂估入账的原材料有成本差异吗
  • php时间戳转换中国标准时间
  • 核定征收印花税的文件
  • 新闻发布管理系统
  • php guzzle 异步
  • 新成立公司建账
  • 权益法转成本法非同一控制下为什么不公允
  • 待抵扣进项税额是什么情况下用的
  • 商业流通企业
  • 税务稽查补税
  • 一般人转小规模政策到什么时候
  • 织梦系统
  • 一般纳税人内账考虑税额吗
  • 股权转让分期付款风险
  • 建筑企业预缴
  • 最新外资企业法实施条例
  • 疫情捐款可以抵扣增值税吗
  • 个人承担社保有哪些
  • 固定资产已提完折旧,但仍在使用,需要定期清理吗?
  • 企业转让固定资产发生的费用可扣除吗
  • 收到返还工会经费账务处理
  • 其他应收款为负数正常吗
  • 企业承担个人所得税分录怎么做
  • 收据可不可以做账
  • 主营业务毛利率和毛利率
  • 企业其他应收款余额非常大的原因
  • 修改企业账套的步骤
  • cmd命令行窗口快捷键
  • windows2008关闭ie增强
  • Windows Server 2008虚拟技术说明
  • /wlan direct
  • 进程acore已停止一直出现怎么办
  • 浅谈linux的发展方向和应用范围
  • win8创建系统映像
  • windows7如何取消锁屏密码
  • unity获取mesh网格数据
  • 用python做逻辑回归
  • javascript还有人用吗
  • android怎么学
  • Android-SQLite商业化数据库操作
  • jQuery bt气泡实现悬停显示及移开隐藏功能的方法
  • jquery实例
  • 卸载python后模块库还用卸载吗
  • 医保银行代扣是什么意思
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设