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

uniapp图片数据流���� JFIF ��C 转化base64

1,后端返回的是图片数据流,格式如下

���� JFIF ��C  如何把这样的文件流转化为base64,

 btoa 是浏览器提供的函数,但在 小程序 环境中(如微信小程序、支付宝小程序),btoa 不可用。你需要手动编写 Base64 编码逻辑或者使用第三方库

2,uniapp调用接口

export  async function getImgFn(objectKey,md5){const res =await uni.request({url:ip地址,header: {'VerificationToken': 12,   //请求头根据你的要求传,我这里没有要求},method: "GET",responseType: 'arraybuffer', });let base64img='data:image/jpeg;base64,' + base64Encode(res.data)  //手动写一个base64Encode方法return base64img;}

3,手动写一个base64Encode数据流转base64方法

function base64Encode(buffer) {const base64Chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";let binary = '';const bytes = new Uint8Array(buffer);const len = bytes.byteLength;for (let i = 0; i < len; i++) {binary += String.fromCharCode(bytes[i]);}let base64 = '';let padding = '';let remainder = binary.length % 3;if (remainder > 0) {for (let i = 0; i < 3 - remainder; i++) {padding += '=';binary += '\0';}}for (let i = 0; i < binary.length; i += 3) {const n = (binary.charCodeAt(i) << 16) |(binary.charCodeAt(i + 1) << 8) |binary.charCodeAt(i + 2);base64 += base64Chars[(n >> 18) & 63] +base64Chars[(n >> 12) & 63] +base64Chars[(n >> 6) & 63] +base64Chars[n & 63];}return base64.substring(0, base64.length - padding.length) + padding;}

http://www.lryc.cn/news/507450.html

相关文章:

  • django中cookie与session的使用
  • <项目代码>YOLO Visdrone航拍目标识别<目标检测>
  • GhostRace: Exploiting and Mitigating Speculative Race Conditions-记录
  • OPPO 数据分析面试题及参考答案
  • 腾讯云云开发 Copilot 深度探索与实战分享
  • Mac M1使用pip3安装报错
  • flask-admin的modelview 实现list列表视图中扩展修改状态按钮
  • 算法训练第二十三天|93. 复原 IP 地址 78. 子集 90. 子集 II
  • imu相机EKF
  • 【杂谈】虚拟机与EasyConnect运行巧设:Reqable助力指定应用流量专属化
  • 【AI系列】Paddle Speech安装指南
  • 【AI学习】OpenAI推出o3,向AGI迈出关键一步
  • 深度学习0-前置知识
  • Elasticsearch-分词器详解
  • Android-相对布局RelativeLayout
  • Centos7, 使用yum工具,出现 Could not resolve host: mirrorlist.centos.org
  • 在Linux中使用`scp`进行远程目录文件复制
  • VisionPro 机器视觉案例 之 连接件测量
  • C++ 中面向对象编程中对象的状态存储与恢复的处理
  • ip_output函数
  • 【win10+RAGFlow+Ollama】搭建本地大模型助手(教程+源码)
  • 现代风格VUE3易支付用户控制中心
  • CentOS 7 上自动安装 Python 3.9 脚本
  • Spring(二)---基于注解的方式实现Bean管理和注入属性
  • 采购管理系统的设计与实现【文档+源码】
  • Overleaf编译运行时间太长,国内如何支付升级Overleaf高级账户?
  • UE5喷涂功能
  • Unity局部和世界坐标系相互转换的实现原理
  • MySQL通用语法 -DDL、DML、DQL、DCL
  • C# 6.0 连接elasticsearch数据库