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

  • 3招教你写出受欢迎的软文(受怎样写)

    3招教你写出受欢迎的软文(受怎样写)

  • 荣耀无线耳机怎么连接手机(荣耀无线耳机怎么连接电脑)

    荣耀无线耳机怎么连接手机(荣耀无线耳机怎么连接电脑)

  • 苹果12pro max电池百分比怎么设置(苹果12promax电池容量有多大)

    苹果12pro max电池百分比怎么设置(苹果12promax电池容量有多大)

  • 钉钉怎么开启在线课堂(钉钉怎么开启在线课堂保存功能怎么回事)

    钉钉怎么开启在线课堂(钉钉怎么开启在线课堂保存功能怎么回事)

  • 中国移动积分兑换的物品怎么查物流(中国移动积分兑换)

    中国移动积分兑换的物品怎么查物流(中国移动积分兑换)

  • 华为nova5如何退出程序(华为nova5怎么退出后方程序)

    华为nova5如何退出程序(华为nova5怎么退出后方程序)

  • 淘宝延长收货后还可以退货吗(淘宝延长收货后运费险还能用吗)

    淘宝延长收货后还可以退货吗(淘宝延长收货后运费险还能用吗)

  • 空白页怎么就删除不了(空白页怎么删除不了)

    空白页怎么就删除不了(空白页怎么删除不了)

  • 电脑闲置太久开不了机(电脑闲置太久开机屏幕出现很多英文)

    电脑闲置太久开不了机(电脑闲置太久开机屏幕出现很多英文)

  • 手机屏幕对眼睛有伤害吗(手机屏幕对眼睛好的是哪种屏)

    手机屏幕对眼睛有伤害吗(手机屏幕对眼睛好的是哪种屏)

  • 荣耀30散热方式(荣耀30散热方式怎么样)

    荣耀30散热方式(荣耀30散热方式怎么样)

  • 打印机没有网络可以打印吗(打印机没有网络怎么连接手机打印)

    打印机没有网络可以打印吗(打印机没有网络怎么连接手机打印)

  • 腾讯视频微信账号可以两个手机同时使用吗(腾讯视频微信账号如何让别人登录)

    腾讯视频微信账号可以两个手机同时使用吗(腾讯视频微信账号如何让别人登录)

  • 计算机病毒是指在计算机磁盘上进行自我复制的(计算机病毒是指具有破坏性的)

    计算机病毒是指在计算机磁盘上进行自我复制的(计算机病毒是指具有破坏性的)

  • aqm-al00是华为什么型号手机(aqm-al00是华为什么型号荣耀)

    aqm-al00是华为什么型号手机(aqm-al00是华为什么型号荣耀)

  • 喜马拉雅审核不过原因(喜马拉雅为什么待审核)

    喜马拉雅审核不过原因(喜马拉雅为什么待审核)

  • 12306只能候补一个订单吗(12306只能候补一趟车吗)

    12306只能候补一个订单吗(12306只能候补一趟车吗)

  • 荣耀20可以双击亮屏吗(荣耀20可以双击截图吗)

    荣耀20可以双击亮屏吗(荣耀20可以双击截图吗)

  • 抖音三角什么意思(抖音里的三角符号是什么意思)

    抖音三角什么意思(抖音里的三角符号是什么意思)

  • 苹果录音功能在哪(苹果录音功能在哪设置)

    苹果录音功能在哪(苹果录音功能在哪设置)

  • 手机分辨率是什么意思(手机分辨率什么样的最好)

    手机分辨率是什么意思(手机分辨率什么样的最好)

  • 华为支付保护中心有用吗(华为支付保护中心提示恢复)

    华为支付保护中心有用吗(华为支付保护中心提示恢复)

  • 荣耀note10能不能开空调(荣耀note10能不能插内存卡)

    荣耀note10能不能开空调(荣耀note10能不能插内存卡)

  • p30三个摄像头分别是做什么的(p30三个摄像头分别是什么)

    p30三个摄像头分别是做什么的(p30三个摄像头分别是什么)

  • 欠费时的短信怎么查看(欠费期间的短信怎么办)

    欠费时的短信怎么查看(欠费期间的短信怎么办)

  • 为什么ipad下载东西手机上也有(为什么ipad下载微信要购买)

    为什么ipad下载东西手机上也有(为什么ipad下载微信要购买)

  • 微信小程序登录方法,授权登陆及获取微信用户手机号(微信小程序登录后端)

    微信小程序登录方法,授权登陆及获取微信用户手机号(微信小程序登录后端)

  • 织梦dedemcs升级最新版本技巧和升级后出现的问题解答(织梦系统)

    织梦dedemcs升级最新版本技巧和升级后出现的问题解答(织梦系统)

  • 建筑业增值税税负预警
  • 小规模纳税人不开票收入怎么报增值税
  • 二手房交易税费最新规定
  • 房租收到专票账务处理
  • 子公司注销资金还母公司冲实收资本吗
  • 企业转让无形资产使用权取得的收入应计入营业外收入
  • 2021留美学生签证
  • 应收账款入账金额的确定方法
  • 外贸企业采购货物会计分录
  • 支付境外咨询费代扣代缴企业所得税
  • 当月增次月是什么意思
  • 监控安装属于什么税目
  • 关联企业股份
  • 建安业一般纳税人企业所得税率是多少
  • 生活支出计入什么科目
  • 企业收到进项发票
  • 减免税款交企业所得税吗
  • 银行代扣社保怎么做会计分录
  • 高新技术企业研发费
  • 已抵扣原材料进项税额转出完整分录
  • 专项扣除项目有上限吗
  • 企业收到财政资金
  • 电脑右下角弹出网页没有×怎么关闭
  • php中cookie的值存储在哪
  • 多台电脑如何建立局域网
  • 最强超频
  • 发票怎么保管不会坏
  • 收到税务局退增值税及附加税怎么做账
  • laravel insert ignore
  • 井下生产安全知识
  • 小微企业免税额的会计分录
  • siri怎么重置主人声音ios13
  • 盘亏前累计折旧怎么算
  • vue table导出excel
  • mysqlmha高可用
  • win11预览版22000.51
  • yii框架入门
  • 如何查看python模块的依赖包
  • 淘宝运费险费用很高
  • 未签订劳动合同辞退赔偿金怎么算
  • 销售免税农产品如何开票
  • 九步功法
  • vue生命周期钩子函数
  • 纳税申报表上的销售额
  • 补缴去年的附加税怎么算
  • 出差的招待费算差旅费
  • 股权变更涉及土地增值税吗
  • sqlserver创建维护计划
  • 采用汇兑的方式归还前欠货款
  • 投资性房地产出售收入属于什么收入
  • mysql主从复制实现原理
  • 企业收到合同保险怎么办
  • 关于餐饮行业
  • 捐赠支出入账
  • 营改增后预交营业税怎么处理
  • 给员工租的房子水电费谁出
  • 什么是划分?划分应当遵守哪些规则?
  • 微软数据收集
  • freebsd软件包存储库
  • dos命令提示符窗口怎么打开
  • linux系统的配置设计过程
  • 密钥升级win10专业版有问题吗
  • linux服务器安全防护方案
  • windows补丁kb3033929
  • win7电脑浏览器怎么设置默认浏览器
  • js的forin
  • js浏览器打印
  • jquery手风琴折叠菜单
  • material design app
  • media and
  • 局域网如何打开共享文件夹
  • nodejs 路由
  • nodejs使用视频教程
  • javascript的
  • android software
  • android入门基础知识
  • js操作网页
  • javascript的理解
  • 安卓端测试
  • 高速公路通行费的税率
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设