JS二进制文件转换:File、Blob、Base64、ArrayBuffer
类型转换
1. Blob、File → Base64
function fileToDataURL(file) {let reader = new FileReader();reader.readAsDataURL(file);reader.onload = function (e) {return reader.result;};
}
2. Base64 → Blob、File
// Base64 转为 Blob
function dataURLToBlob(fileDataURL) {let arr = fileDataURL.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
function dataURLToBlob(fileDataURL, filename) {let arr = fileDataURL.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 File([u8arr], filename, { type: mime });
}
3. Blob、File → Object URL
// object:用于创建 URL 的 File 对象、Blob 对象
const objectUrl = URL.createObjectURL(object)
4. ArrayBuffer → Blob
const blob = new Blob([new Uint8Array(buffer, byteOffset, length)])
5. ArrayBuffer → base64
const base64 = btoa(String.fromCharCode.apply(null, new Uint8Array(arrayBuffer)))
6. Blob → ArrayBuffer
function blobToArrayBuffer (blob) { const reader = new FileReader()reader.readAsArrayBuffer(blob)reader.onload = () =>{return reader.result;}
}
7. Blob、File 文件数据绘制到 canvas
// 思路:Blob、File ——> dataURL(Base64) ——> canvas
function fileAndBlobToCanvas(fileDataURL) {let img = new Image()img.src = fileDataURLlet canvas = document.createElement('canvas')if (!canvas.getContext) {alert('浏览器不支持canvas')return}let ctx = canvas.getContext('2d')document.getElementById('container').appendChild(canvas)img.onload = function () {ctx.drawImage(img, 0, 0, img.width, img.height)}
}
8. 从 canvas 中获取文件 Base64
function canvasToDataURL() {let canvas = document.createElement('canvas')let canvasDataURL = canvas.toDataURL('image/png', 1.0)return canvasDataURL
}
相关文章:
JS二进制文件转换:File、Blob、Base64、ArrayBuffer
类型转换 1. Blob、File → Base64 function fileToDataURL(file) {let reader new FileReader();reader.readAsDataURL(file);reader.onload function (e) {return reader.result;}; }2. Base64 → Blob、File // Base64 转为 Blob function dataURLToBlob(fileDataURL) …...
编译opencv gpu版的条件
一、具备以下条件即可编译opencv gpu: 1、 终端设备必须有独立显卡。cmd窗口:nvidia-smi查看显卡信息 2、下载并安装CUDA Toolkit(根据显卡下载对应的CUDA Toolkit软件)、cuDNN(根据CUDA版本下载对应的cuDNN࿰…...
List集合的Stream流式操作实现数据类型转换
问题现象: 最近在项目中,有一些逻辑想用List集合的Stream流式操作来快速实现,但由于之前没做好学习笔记和总结,导致一时间想不起来,只能用本方法来解决,如下: 可以看出来代码量是比较冗长的&…...
Ubuntu 20.04.6 LTS下edge浏览器点击图标没反应
1.网上的解决方案 解决Ubuntu系统下启动root账户后Linux版本edge浏览器无法启动等 2.采用的解决方案 之前我一直是在官网下载 Microsoft Edge下载,安装,卸载,重装的stable版本,然后安装,始终没有效果。 最后利用Linux…...
php基础学习之错误处理(其一)
一,错误处理的概念 错误处理指的是系统(或者用户)在执行某些代码的时候,发现有错误,就会通过错误处理的形式告知程序员,俗称报错 二,错误分类 语法错误:书写的代码不符合 PHP 的语法规范,语法错…...
Nginx 解析漏洞复现
环境搭建 下载之后上传到虚拟机并解压 进入这个路径 (root?kali)-[~/vulhub-master/nginx/nginx_parsing_vulnerability]就能看到有docker-compose.yml 启动环境 正常显示 增加/.php后缀,被解析成PHP文件: 漏洞原因:开启了cgi.fix_pathin…...
JQMobile Loader Widget 遮罩层改造
最近在用jqmobile 做一个混合APP项目时候用到 jqmobile1.4.3提供的Loader Widget控件,但是这个控件本身是一个loading弹出层,这个弹出层弹出之后,用户还是可以去点击按钮,重复发送请求,为了防止重复提交,我想了两种办法, 1,在loading弹出层弹出之后,让按钮不可用.但是form表单…...
练习 2 Web [ACTF2020 新生赛]BackupFile 1
[ACTF2020 新生赛]BackupFile 1 Web常规题目 首先尝试查找常见的前端页面index.php之类的,没找到 题目有个“BackupFile”——备份文件 尝试用工具遍历查找相关的文件 御剑没扫出来,搜索搭建好dirsearch后,扫出来的index.php.bak 扫描工…...
【python】subprocess用法示例
当然,下面是一些使用 Python subprocess 模块的示例: 1. 运行命令并捕获输出 import subprocess # 运行 ls 命令并捕获输出 result subprocess.run([ls, -l], stdoutsubprocess.PIPE, stderrsubprocess.PIPE, textTrue) # 获取命令的输出和错误信息 o…...
Socket网络编程(三)——TCP快速入门
目录 概述TCP连接可靠性1. 三次握手过程2. 四次挥手过程3. 为什么挥手需要四次? 传输可靠性TCP核心APITCP传输初始化配置&建立连接客户端创建Socket建立连接服务端创建ServerSocket监听连接ServerSocket 和 Socket的关系 Socket基本数据类型传输客户端数据传输服…...
皇冠测评:网络电视盒子哪个品牌好?电视盒子排行榜
欢迎各位来到我们的测评频道,本期我们要分享的产品是电视盒子,因很多网友留言不知道网络电视盒子哪个品牌好,我们通过为期一个月的测评后整理了电视盒子排行榜,想买电视盒子的可以看看下面这五款产品,它们各方面表现非…...
simple-pytest 框架使用指南
simple-pytest 框架使用指南 一、框架介绍简介框架理念:框架地址 二、实现功能三、目录结构四、依赖库五、启动方式六、使用教程1、快速开始1.1、创建用例:1.2、生成py文件1.3、运行脚本1.3.1 单个脚本运行1.3.2 全部运行 1.4 报告查看 2、功能介绍2.1、…...
React中使用useActive
1.引入 import { useActivate } from "react-activation";2.React Activation 在React中使用react-activation,其实就是类似于Vue中的keep-alive,实现数据的缓存; 源码: import { ReactNode, ReactNodeArray, Context, Component…...
ElasticSearch安装和kibana控制台安装
文章目录 简介ElasticSearch安装环境下载参数密码配置启动 kibana安装修改config/kibana.yml配置 简介 Elasticsearch 是一个分布式文档存储。Elasticsearch 是存储已序列化为 JSON 文档的复杂数据结构。当集群中有多个 Elasticsearch 节点时,存储的文档分布在整个…...
VSCode安装与使用详细教程
一、引言 简要介绍VSCode(Visual Studio Code)是什么,它的主要特点和用途,以及为什么选择VSCode作为代码编辑器。 二、下载与安装 访问VSCode官方网站下载页面。选择适合操作系统的版本(Windows、macOS、Linux&…...
土壤墒情监测站的工作原理
TH-TS600】土壤湿度监测系统是一种用于实时监测土壤湿度的设备系统,通过多个传感器和数据采集设备组合而成。该系统能够安装在农田、果园、草地等不同类型的土壤中,实时监测土壤的水分含量,并将数据传输到数据采集设备中进行记录和分析。 土…...
Flutter 多标签页显示 有关TabController需要知道的知识
背景 很多应用都需要导航栏加多个标签页的方式来构建一个多页显示逻辑,比如购物软件常有:已完成,已发货,待付款三个顶部导航按钮,点击则下面的页面显示不同属性的订单 正文 在flutter中,实现这样的功能需…...
【Elasticsearch专栏 16】深入探索:Elasticsearch的Master选举机制及其影响因素分析
Elasticsearch,作为当今最流行的开源搜索和分析引擎,以其分布式、可扩展和高可用的特性赢得了广大开发者的青睐。在Elasticsearch的分布式架构中,集群的稳健性和高可用性很大程度上依赖于其Master节点的选举机制。本文将深入剖析Elasticsearc…...
Leetcode : 215. 数组中的第 K 个最大元素
给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。 请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。 你必须设计并实现时间复杂度为 O(n) 的算法解决此问题。 思路:最开始排序算法&…...
node express实现Excel文档转json文件
有些场景我们需要将Excel文档中的内容抽取出来生成别的文件,作为一个前端,服务框架最应该熟悉的就是node了,以下是基于多语言转换实现代码,看明白原理自己改一改就能用了 1.安装node环境 2.创建一个文件夹,文件夹中创建…...
Android WebView 中 React useState 更新失效问题
1. 问题 在 Android App 内嵌的 H5 页面(React)中: 打开文件选择器上传图片后,页面所有 useState 的更新(如 setLoading、setRecordList)都不生效接口返回数据正常,但页面不渲染原生 DOM 操作正…...
用Python+Matplotlib分析你的游戏战绩:手把手教你画多组数据对比箱线图
用PythonMatplotlib分析你的游戏战绩:手把手教你画多组数据对比箱线图 每次游戏结束后,看着战绩面板上密密麻麻的数字,你是否好奇自己最擅长的英雄究竟是哪个?或者想知道在不同时间段的表现稳定性如何?箱线图…...
如何快速掌握SAM-HQ:从源码编译到自定义模块扩展的完整指南
如何快速掌握SAM-HQ:从源码编译到自定义模块扩展的完整指南 【免费下载链接】sam-hq Segment Anything in High Quality [NeurIPS 2023] 项目地址: https://gitcode.com/gh_mirrors/sa/sam-hq SAM-HQ(Segment Anything in High Quality࿰…...
基于c/c++实现linux/windows跨平台获取ntp网络时间戳
目录使用场景c/c源码结果验证windows编译命令linux编译命令输出结果使用场景 在项目中,有时需要根据时钟同步做一些操作,例如网络请求、多设备视频同步播放等。 在多设备同步播放视频的环境中,我们可以定时请求网络时间,并根据每…...
你的USB2.0设备总掉线?可能是这3个电路设计细节没做好(附EMC整改实测案例)
USB2.0设备频繁断连的硬件陷阱:工程师必知的三大电路设计盲区 当你的医疗监护仪在ICU病房突然失去体征数据传输,或是工业控制台在产线上反复弹出"设备未识别"警告时,背后往往隐藏着硬件工程师最容易忽视的三个电路设计细节。这些看…...
从‘阴谋论’到代码:用Python和PyTorch亲手实现Dropout,搞懂训练测试为啥要‘精分’
从神经元"社交恐惧症"到代码实战:用Python拆解Dropout的双面人生 想象一下你正在组织一场大型团队建设活动——如果每次分组时都强制打乱成员组合,禁止小团体固化,会发生什么?那些总依赖特定搭档的"社交恐惧型&quo…...
Mac上Maven编译报错?别急着换Lombok版本,先检查你的JDK和Maven版本匹配
Mac上Maven编译报错?别急着换Lombok版本,先检查你的JDK和Maven版本匹配 作为一名长期在MacOS环境下进行Java开发的工程师,我遇到过无数次Maven编译报错的情况。其中最令人头疼的莫过于java.lang.ExceptionInInitializerError: com.sun.tools.…...
【实战】RuoYi-Vue开发环境一站式部署:从零到一启动前后端分离项目
1. 环境准备:从零搭建基础组件 刚接触RuoYi-Vue时,最头疼的就是环境搭建。记得我第一次部署时,光是处理各种依赖冲突就花了整整两天。现在把踩坑经验总结成这份保姆级教程,帮你半小时搞定全套环境。 JDK安装是第一个门槛。推荐使…...
终极指南:如何用GPSTest精准测试手机卫星导航性能
终极指南:如何用GPSTest精准测试手机卫星导航性能 【免费下载链接】gpstest The #1 open-source Android GNSS/GPS test program 项目地址: https://gitcode.com/gh_mirrors/gp/gpstest 你的手机GPS到底有多准?🌍 通过GPSTest这款顶级…...
Inno Setup 6中文安装包制作全攻略:从下载汉化到自定义脚本进阶
Inno Setup 6中文安装包制作全攻略:从汉化到脚本定制实战 在软件开发的生命周期中,专业化的安装程序是产品交付的重要环节。对于中文开发者而言,一个支持本地化、具备自定义功能的安装包不仅能提升用户体验,更能体现产品的专业度。…...
