当前位置: 首页 > news >正文

base64转二进制流,file文件

base64转二进制流

img标签src属性,可以直接使用base64字符串,base64需要先解码,然后再转为流

/*** Base64字符串转二进制流* @param {String} dataurl Base64字符串(字符串包含Data URI scheme,例如:data:image/png;base64, )*/
function dataURLtoBlob(dataurl) {var arr = dataurl.split(","),mime = arr[0].match(/:(.*?);/)[1],bstr = atob(arr[1]),n = bstr.length,u8arr = new Uint8Array(n);while (n--) {u8arr[n] = bstr.charCodeAt(n);}return new Blob([u8arr], {type: mime,});
}

base64转file

img标签src属性,可以直接使用base64字符串,base64需要先解码,然后再转为文件

/*** Base64字符串转File文件* @param {String} dataurl Base64字符串(字符串包含Data URI scheme,例如:data:image/png;base64, )* @param {String} filename 文件名称*/
function dataURLtoFile(dataurl, filename) {let arr = dataurl.split(',');let mime = arr[0].match(/:(.*?);/)[1];let bstr = atob(arr[1]);let n = bstr.length;let u8arr = new Uint8Array(n);while (n--) {u8arr[n] = bstr.charCodeAt(n);}return new File([u8arr], filename, {type: mime});
}

文件转base64

let fileReader = new FileReader()file.onchange = function (e) {console.log(e.target.files); //可以查到对应上传的文件,file是继承blob的对象fileReader.readAsDataURL(e.target.files[0])//转base64fileReader.onload = function (res) { console.log(res.target.result); }//显示base64的字符串}

流转base64

/*** 二进制流转Base64(字符串包含Data URI scheme)* @param {Object} data 二进制流* @param {String} type 文件类型(例如:image/png)*/
function getDataURL(data, type) {return new Promise((resolve, reject) => {const blob = new Blob([data], {type});const reader = new FileReader();reader.readAsDataURL(blob);reader.onload = () => resolve(reader.result);reader.onerror = (error) => reject(error);});
}
http://www.lryc.cn/news/116486.html

相关文章:

  • 各种查找算法的效率分析
  • 微报告下载!市场不确定性周期下的激光雷达前装赛道
  • Java版企业电子招标采购系统源码Spring Cloud + Spring Boot +二次开发+ MybatisPlus + Redis tbms
  • 并网逆变器学习笔记6---三电平SVPWM下的连续和不连续调制
  • TS协议之PES(ES数据包)
  • 银河麒麟V10 SP3 X86 二进制文件部署 mysql-5.7.29 GTID 半同步复制的双主架构
  • python爬虫3:requests库-案例1
  • 计算机网络 数据链路层 媒体接入控制
  • 面部表情识别(Pytorch):人脸检测模型+面部表情识别分类模型
  • 外卖点餐小程序开源源码——支持扫码点餐
  • 十分钟掌握使用 SolidJS 构建全栈 CRUD 应用程序
  • LabVIEW开发多材料摩擦电测量控制系统
  • 【Linux】网络基础1
  • HTML - Javascript - 原生的JS HTTP请求:实用主义的一篇文章
  • Intellij IDEA运行报Command line is too long的解决办法
  • 信号槽传输过程中指针所指对象的生命周期
  • c++ 递归锁的使用
  • Oracle TDE wallet
  • 多模态学习
  • Android学习之路(2) 文本设置
  • 手写springboot
  • 报错Uncaught (in promise) Error: Manifest request to...
  • 微信私域更好玩了
  • 基于ant-design的a-modal自定义vue拖拽指令
  • 【ES】笔记-模板字符串(template string)是增强版的字符串`${expresions}`
  • 利用 OLE 对象漏洞的 HWP 恶意文件浮出水面
  • 【CSS】倾斜按钮
  • js 正则表达式
  • 心理咨询预约管理系统javaweb医院挂号jsp源代码mysql
  • Linux中安装Node