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

  • APP推广遇障碍?看看是不是这九种原因(推广app会遇到什么风险)

    APP推广遇障碍?看看是不是这九种原因(推广app会遇到什么风险)

  • 微信实名认证在哪里改(微信实名认证在哪里查看)

    微信实名认证在哪里改(微信实名认证在哪里查看)

  • qq群屏幕分享在哪(qq群里的屏幕分享)

    qq群屏幕分享在哪(qq群里的屏幕分享)

  • 为什么苹果xr不是静音但是来电话没有声音(为什么苹果xr不显示电量)

    为什么苹果xr不是静音但是来电话没有声音(为什么苹果xr不显示电量)

  • 手机qq怎么隐藏超会(手机qq怎么隐藏黄钻图标)

    手机qq怎么隐藏超会(手机qq怎么隐藏黄钻图标)

  • 美团评价怎么修改(美团评价怎么修改匿名)

    美团评价怎么修改(美团评价怎么修改匿名)

  • 荣耀手机nfc功能怎么打开(荣耀手机nfc功能怎么使用公交卡)

    荣耀手机nfc功能怎么打开(荣耀手机nfc功能怎么使用公交卡)

  • 苹果8p微信能上锁吗(苹果8p微信上锁怎么设置)

    苹果8p微信能上锁吗(苹果8p微信上锁怎么设置)

  • 红外感应灯原理(红外线感应灯原理)

    红外感应灯原理(红外线感应灯原理)

  • 怎么看淘宝三年前的聊天记录(怎么看淘宝三年前的物流)

    怎么看淘宝三年前的聊天记录(怎么看淘宝三年前的物流)

  • 拼多多怎么不能用QQ登录了(拼多多怎么不能先用后付了)

    拼多多怎么不能用QQ登录了(拼多多怎么不能先用后付了)

  • 个人大数据是什么意思(个人大数据是什么情况影响的)

    个人大数据是什么意思(个人大数据是什么情况影响的)

  • 智能材料有哪些(智能材料有哪些问题如何解决?)

    智能材料有哪些(智能材料有哪些问题如何解决?)

  • 数组和指针的区别(数组和指针的区别,数组存放两个字符串)

    数组和指针的区别(数组和指针的区别,数组存放两个字符串)

  • 小米10怎么设置呼吸灯(小米10怎么设置隐私相册)

    小米10怎么设置呼吸灯(小米10怎么设置隐私相册)

  • 苹果11怎么设置旋转屏幕(苹果11怎么设置5g网络)

    苹果11怎么设置旋转屏幕(苹果11怎么设置5g网络)

  • 滴滴出行能查出全部行程吗(滴滴出行能查出老公出轨吗)

    滴滴出行能查出全部行程吗(滴滴出行能查出老公出轨吗)

  • 计算机网络什么时候出现的(计算机网络什么时候诞生)

    计算机网络什么时候出现的(计算机网络什么时候诞生)

  • icloud备份要多久(苹果换新手机icloud备份要多久)

    icloud备份要多久(苹果换新手机icloud备份要多久)

  • 电话卡停机不缴费会怎样(手机卡停机不交钱会怎么样)

    电话卡停机不缴费会怎样(手机卡停机不交钱会怎么样)

  • 苹果11夜间模式怎么开(苹果11夜间模式怎么开拍照)

    苹果11夜间模式怎么开(苹果11夜间模式怎么开拍照)

  • 微信原图是什么意思(微信原图是怎么回事)

    微信原图是什么意思(微信原图是怎么回事)

  • 微信怎么发5分钟以上视频(微信怎么发5分钟以上的视频)

    微信怎么发5分钟以上视频(微信怎么发5分钟以上的视频)

  • 怎么将pdf拆开(如何将pdf的文档拆开)

    怎么将pdf拆开(如何将pdf的文档拆开)

  • x27电池容量(vivox27电池容量)

    x27电池容量(vivox27电池容量)

  • 快手第一个作品怎么火(快手第一个作品两千播放量正常吗)

    快手第一个作品怎么火(快手第一个作品两千播放量正常吗)

  • 差额纳税是什么税
  • 零售化妆品交什么税种
  • 工程款按进度付款开票分录
  • 发票章坏了能自己刻吗
  • 一般纳税人当月生效次月生效有什么区别
  • 房屋租赁收入怎么做账
  • 提前给货款计入什么科目
  • 公益性捐赠全额扣除2020年第9号文件
  • 销售现金券会计分录
  • 固定资产折旧属于制造费用吗
  • 退税税额要做进项税转出吗?
  • 固定资产清单申报是什么意思
  • 企业所得税一般是多少
  • 增值税发票已作废怎么办
  • 应交税费算什么费用
  • 增值税发票查验平台怎么查询发票
  • 现金流量表本月数和本年累计数是相等的么
  • 总部员工调往下属单位
  • 私人打款到对公账户可以吗
  • 个体户生产经营所得税率表2023
  • 境外投资企业如何交税
  • 销售退回涉及的科目
  • 投资电影分红款如何开具发票?
  • 在win7系统中,怎么把D盘里的文件移到C盘里?
  • Windows 11 Build 22000.176 (KB5006050) 更新推送(附更新内容+安装)
  • 如何在win11上安装旧版ie
  • 在mac上安装ios应用
  • win11预览版怎么变回正式版
  • 公司资产转让要交多少税
  • 企业接受母公司代为缴纳税款会计分录
  • cda是什么文件格式
  • 市面最高版本
  • 认知度高的人
  • php如何防止xss攻击
  • 净资产和净利润一样吗
  • 土地承包经营权和土地经营权区别
  • php中session使用
  • php并发编程
  • 上年未结转的成本今年可以结转吗
  • 【AIGC】1、爆火的 AIGC 到底是什么 | 全面介绍
  • phpcms如何配置404
  • 交税务局的工会经费现金流
  • 进项税额大于销项税额期末留抵
  • python numpy 删除元素
  • 零税项目
  • sql server 2005 service pack3
  • 投资性房地产进项税抵扣
  • 无偿调入资产如何做账
  • 出口抵减内销产品应纳税额分录
  • 私营企业员工享受探亲假吗
  • 工程外地预缴会计分录
  • 银行电子承兑汇票到期怎么兑现
  • 固定资产开普票还是专票
  • 电商支付的刷单费怎样做记账凭证?
  • 信息服务的最终目的是什么
  • 以前年度的固定资产入成原材料了怎么办
  • 年报和汇算清缴的顺序
  • 食堂没发票如何记账
  • 企业研制新产品
  • mysql的三种查询方式
  • 电脑上的win8键盘怎么打开
  • winxp出现应用程序错误
  • asmb进程
  • Win10预览版怎么变回正式版
  • win7系统安装谷歌浏览器
  • 在linux操作系统中,/etc/rc.d/init.d
  • win10预览版和正式版区别
  • Extjs中通过Tree加载右侧TabPanel具体实现
  • echarts splitnumber
  • ubuntu重新安装网卡驱动
  • rgb颜色相加
  • vue.js如何使用
  • javascript:void(0)的作用示例介绍
  • python二叉树
  • zabbix 微信
  • android基础入门教程
  • 甘肃省政府非税收入电子发票在哪里打印
  • 辽宁省国家税务总局
  • 为什么国税网上申报不了
  • 关税是什么
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设