Base64编码原理:二进制数据与文本的转换技术
🔄 Base64编码原理:二进制数据与文本的转换技术
开发者的数据编码困境
作为开发者,你是否曾遇到这些与Base64相关的挑战:
- 📊 需要在JSON中传输二进制数据,但不确定如何正确编码
- 🖼️ 想要在HTML或CSS中内联小型图片,但处理过程繁琐
- 📧 开发邮件系统时,附件编码处理导致各种乱码问题
- 🔐 处理认证令牌或签名时,需要精确的编码转换
- 📱 跨平台应用中,不同环境的Base64实现存在细微差异
研究表明,超过60%的Web和移动应用开发者每周至少需要处理一次Base64编码问题,而其中约有40%的人对Base64的内部工作原理知之甚少,导致在处理特殊字符、填充规则或大型数据时出现各种问题。
Base64编码的技术原理深度解析
1. Base64编码算法的核心实现
Base64是一种将二进制数据转换为可打印ASCII字符的编码方式。以下是其核心实现原理:
/*** Base64编码解码器* 实现二进制数据与Base64文本的相互转换*/
class Base64Codec {constructor() {// 标准Base64字符集this.STANDARD_CHARSET = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';// URL安全的Base64字符集(替换+和/)this.URL_SAFE_CHARSET = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_';// 填充字符this.PADDING_CHAR = '=';}/*** 将二进制数据编码为Base64字符串* @param {Uint8Array|ArrayBuffer|string} data - 要编码的数据* @param {Object} options - 编码选项* @param {boolean} options.urlSafe - 是否使用URL安全字符集* @param {boolean} options.noPadding - 是否省略填充字符* @returns {string} Base64编码的字符串*/encode(data, options = {}) {// 默认选项const { urlSafe = false, noPadding = false } = options;// 选择字符集const charset = urlSafe ? this.URL_SAFE_CHARSET : this.STANDARD_CHARSET;// 确保数据是Uint8Array格式let bytes;if (typeof data === 'string') {bytes = this._stringToUint8Array(data);} else if (data instanceof ArrayBuffer) {bytes = new Uint8Array(data);} else if (data instanceof Uint8Array) {bytes = data;} else {throw new Error('不支持的数据类型');}let result = '';const len = bytes.length;// 每3个字节一组进行处理for (let i = 0; i < len; i += 3) {// 将3个8位字节组合成一个24位数字const byte1 = bytes[i];const byte2 = i + 1 < len ? bytes[i + 1] : 0;const byte3 = i + 2 < len ? bytes[i + 2] : 0;const triplet = (byte1 << 16) | (byte2 << 8) | byte3;// 将24位数字拆分为4个6位索引const index1 = (triplet >> 18) & 0x3F;const index2 = (triplet >> 12) & 0x3F;const index3 = (triplet >> 6) & 0x3F;const index4 = triplet & 0x3F;// 根据索引查找对应的Base64字符result += charset[index1] + charset[index2];// 处理填充if (i + 1 < len) {result += charset[index3];} else if (!noPadding) {result += this.PADDING_CHAR;}if (i + 2 < len) {result += charset[index4];} else if (!noPadding) {result += this.PADDING_CHAR;}}return result;}/*** 将Base64字符串解码为二进制数据* @param {string} str - Base64编码的字符串* @param {Object} options - 解码选项* @param {boolean} options.urlSafe - 是否使用URL安全字符集* @param {boolean} options.outputString - 是否输出字符串而非Uint8Array* @returns {Uint8Array|string} 解码后的数据*/decode(str, options = {}) {// 默认选项const { urlSafe = false, outputString = false } = options;// 选择字符集const charset = urlSafe ? this.URL_SAFE_CHARSET : this.STANDARD_CHARSET;// 创建字符到索引的映射const charToIndex = new Map();for (let i = 0; i < charset.length; i++) {charToIndex.set(charset[i], i);}// 移除所有非Base64字符(包括填充)let cleanStr = str.replace(/[^A-Za-z0-9+/\-_]/g, '');// 计算填充长度const paddingLength = str.endsWith('==') ? 2 : (str.endsWith('=') ? 1 : 0);// 计算输出长度const outputLength = Math.floor(cleanStr.length * 3 / 4) - paddingLength;const result = new Uint8Array(outputLength);let outputIndex = 0;// 每4个字符一组进行处理for (let i = 0; i < cleanStr.length; i += 4) {// 获取4个6位索引const index1 = charToIndex.get(cleanStr[i]) || 0;const index2 = charToIndex.get(cleanStr[i + 1]) || 0;const index3 = (i + 2 < cleanStr.length) ? charToIndex.get(cleanStr[i + 2]) || 0 : 0;const index4 = (i + 3 < cleanStr.length) ? charToIndex.get(cleanStr[i + 3]) || 0 : 0;// 组合成一个24位数字const triplet = (index1 << 18) | (index2 << 12) | (index3 << 6) | index4;// 拆分为3个8位字节if (outputIndex < outputLength) {result[outputIndex++] = (triplet >> 16) & 0xFF;}if (outputIndex < outputLength) {result[outputIndex++] = (triplet >> 8) & 0xFF;}if (outputIndex < outputLength) {result[outputIndex++] = triplet & 0xFF;}}return outputString ? this._uint8ArrayToString(result) : result;}/*** 将字符串转换为Uint8Array* @param {string} str - 输入字符串* @returns {Uint8Array} 转换后的字节数组* @private*/_stringToUint8Array(str) {const encoder = new TextEncoder();return encoder.encode(str);}/*** 将Uint8Array转换为字符串* @param {Uint8Array} bytes - 字节数组* @returns {string} 转换后的字符串* @private*/_uint8ArrayToString(bytes) {const decoder = new TextDecoder();return decoder.decode(bytes);}
}
2. Base64编码的数学原理
Base64编码的核心思想是将3个8位字节(共24位)重新分组为4个6位单元,然后将每个6位单元映射到一个可打印字符。这种转换过程可以用以下数学公式表示:
输入: 3个字节 = 24位 = [b1, b2, b3]
输出: 4个索引 = [i1, i2, i3, i4]i1 = (b1 >> 2) & 0x3F
i2 = ((b1 & 0x03) << 4) | ((b2 >> 4) & 0x0F)
i3 = ((b2 & 0x0F) << 2) | ((b3 >> 6) & 0x03)
i4 = b3 & 0x3F
这种转换导致Base64编码后的数据大小增加约33%(每3字节变为4字节),但确保了所有数据都可以用可打印字符表示。
现有Base64工具的局限性分析
在研究和使用多种Base64编码工具后,我发现它们普遍存在以下问题:
- 处理大型数据性能差:许多在线工具在处理大文件时性能下降明显或直接崩溃
- 特殊格式支持有限:缺乏对URL安全Base64、无填充Base64等变体的支持
- 二进制文件处理不友好:图片、PDF等二进制文件的编码解码体验不佳
- 批量处理能力弱:不支持批量文件或文本的编码解码
- 隐私安全问题:许多在线工具将数据发送到服务器处理,存在数据泄露风险
针对这些问题,我开发了一个更全面的Base64编码解码工具,它具有以下优势:
✅ 高性能实现:优化的算法,支持高效处理大型数据
✅ 多格式支持:标准Base64、URL安全Base64、无填充Base64等多种变体
✅ 文件友好:直观的文件拖放界面,支持各种二进制文件
✅ 批量处理:支持批量文本和文件的编码解码
✅ 本地处理:所有操作在浏览器中完成,不上传任何数据
✅ 实时预览:即时查看编码解码结果,提高工作效率
工具界面与使用体验
Base64编码解码器
这个工具为用户提供了直观的Base64编码解码体验:
- 文本模式:直接输入文本进行编码或解码
- 文件模式:拖放或选择文件进行处理
- 格式选项:选择标准Base64、URL安全Base64等格式
- 填充控制:可选择是否使用填充字符
- 批量处理:支持多文本块或多文件批量处理
- 导出选项:将结果导出为文本文件或二进制文件
技术探讨与交流
在开发这个工具的过程中,最具挑战性的部分是处理大型二进制文件的性能优化。特别是在浏览器环境中,如何避免内存溢出并保持UI响应性是一个值得深入研究的问题。我采用了分块处理和Web Workers等技术来解决这些挑战。
你在项目中如何使用Base64?是用于API通信、数据存储,还是其他场景?
对于Base64编码的替代方案,如Base85、Base58等,你有什么使用经验可以分享?它们在哪些场景下比Base64更适合?
欢迎在评论区分享你的经验和想法!
如果你需要一个功能全面的Base64编码解码工具,可以体验我开发的这个工具:Base64编码解码器,也欢迎提出改进建议。
#Base64 #编码技术 #前端开发 #数据处理 #开发工具
相关文章:
Base64编码原理:二进制数据与文本的转换技术
🔄 Base64编码原理:二进制数据与文本的转换技术 开发者的数据编码困境 作为开发者,你是否曾遇到这些与Base64相关的挑战: 📊 需要在JSON中传输二进制数据,但不确定如何正确编码🖼️ 想要在HT…...
系统设计(1)—前端—CDN—Nginx—服务集群
简介: 本指南旨涵盖前端、CDN、Nginx 负载均衡、服务集群、Redis 缓存、消息队列、数据库设计、熔断限流降级以及系统优化等模块的核心要点。我们将介绍各模块常见的设计方案与优化策略,并结合电商秒杀、SaaS CRM 系统、支付系统等高并发场景讨论实践技巧…...
Easysearch 基础运维扫盲指南:从 HTTP 到 HTTPS、认证与安全访问全解析
Easysearch 基础运维扫盲指南:从 HTTP 到 HTTPS、认证与安全访问全解析 众所周知,原生 Elasticsearch 默认开启的是 HTTP 明文接口,并且不开启任何身份认证或传输加密。若想启用 TLS/SSL 加密及账号密码验证,通常需要配置繁琐的安…...
在Android中如何使用Protobuf上传协议
在 Android 中使用 Protobuf(Protocol Buffers)主要分为以下几个步骤: ✅ 1. 添加 Protobuf 插件和依赖 在项目的 build.gradle(Project 级)文件中添加 Google 的 Maven 仓库(通常默认已有)&am…...
【数据可视化艺术·应用篇】三维管线分析如何重构城市“生命线“管理?
在智慧城市、能源管理、工业4.0等领域的快速发展中,地下管线、工业管道、电力通信网络等“城市血管”的复杂性呈指数级增长。传统二维管理模式已难以应对跨层级、多维度、动态变化的管线管理需求。三维管线分析技术应运而生,成为破解这一难题的核心工具。…...
2025年的营销趋势-矩阵IP
从 2025 年的营销生态来看,创始人 IP 与智能矩阵的结合确实呈现出颠覆性趋势,这一现象背后隐藏着三个值得深度解析的商业逻辑: 一、创始人 IP 的本质是 "信任货币" 的数字化迁徙 当新能源汽车市场陷入参数混战,雷军将个…...
对接金蝶获取接口授权代码
接口服务信息 using RestSharp; using System.Configuration; using System.Threading.Tasks; public class KingdeeAccessTokenService { private readonly RestClient _client; private readonly KingdeeApiConfig _config; public KingdeeAccessTokenService() …...
探秘 3D 展厅之卓越优势,解锁沉浸式体验新境界
(一)打破时空枷锁,全球触达 3D 展厅的首要优势便是打破了时空限制。在传统展厅中,观众需要亲临现场,且必须在展厅开放的特定时间内参观。而 3D 展厅依托互联网,让观众无论身处世界哪个角落,只…...
prometheus通过Endpoints自定义grafana的dashboard模块
1、prometheus自定义的dashboard模块 文件路径/etc/prometheus/config_out/prometheus-env.yaml - job_name: serviceMonitor/monitoring/pfil/0honor_labels: falsekubernetes_sd_configs:- role: endpointsnamespaces:names:- monitoringrelabel_configs:- source_labels:- …...
java排序算法-计数排序
计数排序的思路 计数排序的基本思路: 确定取值范围: 遍历整个待排序的数组,确定数组中元素的取值范围,找到最小值和最大值。创建计数数组: 创建一个计数数组,其长度为取值范围的大小,用于统计…...
力扣-hot100(滑动窗口最大值)
239. 滑动窗口最大值 困难 给你一个整数数组 nums,有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的 k 个数字。滑动窗口每次只向右移动一位。 返回 滑动窗口中的最大值 。 示例 1: 输入:nums […...
每日c/c++题 备战蓝桥杯(P1049 [NOIP 2001 普及组] 装箱问题)
洛谷P1049 装箱问题题解:动态规划在背包问题中的经典应用 题目描述 P1049 装箱问题是一道典型的0-1背包问题变种。题目要求在给定箱子容量V和n个物品体积的情况下,选择若干物品装入箱子,使得箱子的剩余空间最小。最终输出这个最小剩余空间的…...
【尚硅谷Redis6】自用学习笔记
Redis介绍 Redis是单线程 多路IO复用技术(类似黄牛买票) 默认有16个库,用select进行切换 默认端口号为6379 Memcached:多线程 锁(数据类型单一,不支持持久化) 五大常用数据类型 Redis key …...
产品更新丨谷云科技ETLCloud V3.9.2版本发布
谷云科技 ETLCloud 集成平台迎来了每月一次的功能迭代,本月发布版本号为 3.9.2 版本,为用户带来了新的功能、优化改进以及问题修复,以下是详细介绍: 新增组件 本次更新新增了众多实用组件,涵盖了京东和 Shopify 相关…...
Promise并发控制与HTTP请求优化
Promise并发方法对比 #mermaid-svg-tnmGzOkgNUCrbvfI {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-tnmGzOkgNUCrbvfI .error-icon{fill:#552222;}#mermaid-svg-tnmGzOkgNUCrbvfI .error-text{fill:#552222;stroke…...
G1垃圾回收器中YoungGC和MixedGC的区别
在 G1 垃圾回收器中,Mixed GC 和 Young GC 的区别主要体现在以下几个方面: 作用范围 Young GC:仅针对年轻代中的Region进行回收,包括 Eden 区和 Survivor 区的 Region。Mixed GC:会回收所有年轻代的 Region 以及部分…...
Web4.0身份革命:去中心化身份系统的全栈实现路径
去中心化身份(DID)技术栈正在重构数字世界的信任根基,本文从密码学协议、存储网络、验证框架三个维度,解析符合W3C标准的身份系统构建方案。通过Hyperledger Aries架构实践,揭示如何实现跨链身份互通、数据主权控制、零…...
iOS/Flutter混合开发之PlatformView配置与使用
环境:Xcode 16.3、Flutter 3.29.2、Dart 3.7.2。 使用背景:需要在flutter界面中嵌入一个iOS原生控件。 步骤: 1. iOS侧实现: 1.1:PlatformView实现 class FLNativeView: NSObject, FlutterPlatformView {private v…...
Libconfig 修改配置文件里的某个节点
THCommandStatus ( { Status "1"; index 5; }, { Status "2"; index 8; }, { Status "3"; index 7; }, { Status "4"; index 0; } ); 比如这是配置文件的内容ÿ…...
【金仓数据库征文】_AI 赋能数据库运维:金仓KES的智能化未来
AI 赋能数据库运维:金仓KES的智能化未来 🌟嗨,我是LucianaiB! 🌍 总有人间一两风,填我十万八千梦。 🚀 路漫漫其修远兮,吾将上下而求索。 在当今数字经济飞速发展的时代࿰…...
【MySQL】3分钟解决MySQL深度分页问题
什么是深度分页问题?该如何解决呢?这篇文章展开讲讲 什么是深度分页? 当查询结果集非常大时,需要获取靠后页码的数据,比如第1000页、10000页。 如: SELECT * FROM table LIMIT 10000, 10; -- 获取第10001-10010条…...
GitHub 趋势日报 (2025年04月24日)
本日报由 TrendForge 系统生成 https://trendforge.devlive.org/ 📈 今日整体趋势 Top 10 排名项目名称项目描述今日获星总星数语言1kortix-ai/sunaSuna - Open Source Generalist AI Agent⭐ 1105⭐ 3639TypeScript2cloudcommunity/Free-CertificationsA curated …...
一种双模式机器人辅助股骨干骨折钢板植入方法
股骨干骨折是一种常见的高能损伤,微创内固定是首选治疗方法。然而,钢板植入过程中存在不可见、不准确和不稳定等问题。山东大学研究团队提出了一种双模式机器人辅助钢板植入方法,通过神经网络模型规划钢板植入轨迹,然后利用机械臂…...
全球碳化硅晶片市场深度解析:技术迭代、产业重构与未来赛道争夺战(2025-2031)
一、行业全景:从“材料突破”到“能源革命”的核心引擎 碳化硅(SiC)作为第三代半导体材料的代表,凭借其宽禁带(3.26eV)、高临界击穿场强(3MV/cm)、高热导率(4.9W/cmK&…...
IDEA搭建环境的五种方式
一、普通的java项目 File--New--Project 选择Java,jdk选择1.8版本,然后点next 输入项目名和路径名,点击Finish 创建包结构,编写Class类 编写主方法,输出Hello标志完成 二、普通的javaWeb项目 Java Enterprise-- 勾选…...
隐形革命:环境智能如何重构“人-机-境“共生新秩序
引言 在万物互联的时代,环境智能(Ambient Intelligence, AmI)正以“隐形革命者”的姿态重塑人类生活场景。通过分布式传感器、边缘计算与自适应算法的深度融合,AmI构建出能感知、学习并响应人类行为的智慧环境。 本文基于多领域研…...
Mysql唯一性约束
唯一性约束(Unique Constraint)是数据库设计中用于保证表中某一列或多列组合的值具有唯一性的一种规则。它可以防止在指定列中插入重复的数据,有助于维护数据的完整性和准确性。下面从几个方面为你详细解释 作用 确保数据准确性:…...
QuecPython+GNSS:实现快速定位
概述 QuecPython 结合 GNSS(全球导航卫星系统)模块为物联网设备提供开箱即用的定位能力解决方案。该方案支持 GPS/北斗/GLONASS/Galileo 多系统联合定位,为物联网开发者提供从硬件接入到云端服务的全栈式定位解决方案。 优势特点 多体系定…...
【从零开始:自制一个Java消息队列(MQ)】
🚀 从零开始:自制一个Java消息队列(MQ) 在现代分布式系统中,消息队列(Message Queue,MQ)已经成为一个至关重要的组件。它帮助系统在异步处理、负载均衡、解耦等方面提供了强大的支持…...
WHAT - 已阅读书单
指数基金投资指南✅ 我们终将变富 纳瓦尔宝典 围城✅ 许三观卖血记✅ 骆驼祥子✅ 活着 白鹿原✅ 百年孤独 君主论 阿Q正传✅ 蛤蟆先生去看心理医生✅ 思考,快与慢 三体✅ 人类简史:从动物到上帝✅ 明朝那些事✅ 三国演义✅ 中国历代政治得失✅ 资治…...
代码随想录算法训练营第60期第十七天打卡
今天我们继续进入二叉树的下一个章节,今天的内容我在写今天的博客前大致看了一下部分题目难度不算大,那我们就进入今天的题目。 第一题对应力扣编号为654的题目最大二叉树 这道题目的坑相当多,我第一次题目没有看明白就是我不知道到底是如何…...
C 语言数组详解
一、数组的基本概念 在 C 语言中,数组是一种相同数据类型元素的集合,这些元素在内存中连续存储。通过数组,我们可以用一个统一的名字来管理一组相关的数据,并且通过下标(索引)快速访问其中的每一个元素。例…...
ADVB协议同步
关于视频传输,有多种控制时序。协议标准允许设计者选择有限的几个速率的接口来满足 系统设计目标。例如,一些系统使用总线时序发送信息通过line-by-line;在这个案例中, 容器的sof作为vsync同步的点。horizontal line blanding将插入idles,ADV…...
基于LAB颜色空间的增强型颜色迁移算法
本文算法使用Grok完成所有内容,包含算法改进和代码编写,可大大提升代码编写速度,算法改进速度,提供相关idea,提升效率; 概述 本文档描述了一种基于LAB颜色空间的颜色迁移算法,用于将缩略图D的…...
复合材料高置信度 DIC 测量与高级实验技术研讨会邀请函
邀请函 2025年5月8日 上海 中国复合材料学会官网会议通知 您可以点击上方蓝字跳转官网查看官网信息 主办单位: 中国复合材料学会 协办单位: 研索仪器科技(上海)有限公司 数字图像相关技术(Digital Image Correla…...
解决docker部署MySQL的max_allowed_packet 限制问题
报错 Error querying database. Cause: com.mysql.cj.jdbc.exceptions.PacketTooBigException: Packet for query is too large (2,471 > 2,048). You can change this value on the server by setting the max_allowed_packet variable. ### The error may exist in file …...
【XR手柄交互】Unity 中使用 InputActions 实现手柄控制详解(基于 OpenXR + Unity新输入系统(Input Actions))
摘要: 本文主要介绍如何使用 Input Actions(Unity 新输入系统) OpenXR 来实现 VR手柄控制(监听ABXY按钮、摇杆、抓握等操作)。 🎮 Unity 中使用 InputActions 实现手柄控制详解(基于 OpenXR 新…...
C++:继承机制详解
目录 一.继承的概念及定义 一).继承的概念 二).继承定义 1.定义格式 2.继承类型 3.继承类模板 二.基类和派生类间的转换 三.继承中的作用域 四.派生类的默认成员函数 一).4个常见默认成员函数 二).不可被继承的类 五…...
自然语言处理+知识图谱:智能导诊的“大脑”是如何工作的?
智能导诊系统定义与作用 智能导诊系统是一种基于人工智能技术的医疗辅助工具,旨在提高医疗服务效率、改善患者就医体验、降低医院运营成本,通过自然语言处理技术,智能导诊系统能够自动回答患者的常见问题,帮助患者快速了解自己的…...
论文阅读笔记——ZeroGrasp: Zero-Shot Shape Reconstruction Enabled Robotic Grasping
ZeroGrasp 论文 多视角重建计算大、配置复杂,本文将稀疏体素重建(快且效果好)引入机器人抓取且只考虑单目重建,通过利用基于物理的接触约束与碰撞检测(这对精确抓取至关重要),提升三维重建质量将…...
Qt 调试信息重定向到本地文件
1、在Qt软件开发过程中,我们经常使用qDebug()输出一些调试信息在QtCreator终端上。 但若将软件编译、生成、打包为一个完整的可运行的程序并安装在系统中后,系统中没有QtCreator和编译环境,那应用程序出现问题,如何输出信息排查…...
Android Studio开发中Application和Activity生命周期详解
文章目录 Application生命周期Application生命周期概述Application关键回调方法onCreate()onConfigurationChanged()onLowMemory()onTrimMemory()onTerminate() Application生命周期管理最佳实践 Activity生命周期Activity生命周期概述Activity生命周期回调方法onCreate()onSta…...
vite+vue2+elementui构建之 package.json
webpack版本太低,构建依赖太多,头大。 各种查阅资料,弄了一份直通构建vite构建elementUi核心文件, 构建基于开源若依vue2vue3版本改造,感谢开源,感谢若依。 vitevue2elementui构建之 vite.config.js-CSD…...
安全编排自动化与响应(SOAR):从事件响应到智能编排的技术实践
安全编排自动化与响应(SOAR):从事件响应到智能编排的技术实践 在网络安全威胁复杂度指数级增长的今天,人工处理安全事件的效率已难以应对高频攻击(如日均万级的恶意IP扫描)。安全编排自动化与响应…...
《Keras 3 :使用 TFServing 提供 TensorFlow 模型》
《Keras 3 :使用 TFServing 提供 TensorFlow 模型》 作者:Dimitre Oliveira 创建日期:2023/01/02 最后修改时间:2023/01/02 描述:如何使用 TensorFlow Serving 为 TensorFlow 模型提供服务。 (i) 此示例使用 Keras 3 在 Colab 中查看 GitHub 源 介绍 构建机器学习模…...
深入理解C++ 中的list容器
目录 一、引言 二、list的基本介绍 2.1 底层结构 2.2 特性 三、list的使用 3.1 构造函数 3.2 迭代器的使用 3.3 容量相关操作 3.4 元素访问相关操作 3.5 修改器操作 3.6 迭代器失效问题 四、list的模拟实现 4.1 节点定义 4.2 迭代器实现 4.3 list类实现 五、lis…...
附赠二张图,阐述我对大模型的生态发展、技术架构认识。
文章精炼,用两张图说明大模型发展业态方向,以及大模型主体技术架构。(目前还需要进一步验证我的Thought && ideas,等待机会吧.........) 图一:探究大模型三个层次应用方向,浅层次入门简…...
Java实现加密(七)国密SM2算法的签名和验签(附商用密码检测相关国家标准/国密标准下载)
目录 一、国密标准中,关于SM2签名验签的定义二、SM2签名和验签的实现原理1. 前置知识2. 签名生成过程3. 验签过程4. 数学正确性证明5. 安全性与注意事项 三、带userId、不带userId的区别1. 核心区别2.算法区别(1) 哈希计算过程(2) 签名验签流程 四、Java代码实现1. …...
贪心算法~~
目录 一、理论基础 二、题目练习 (1)455. 分发饼干 (2)53. 最大子数组和 - 力扣 (3)122. 买卖股票的最佳时机 II - 力扣(LeetCode) (4)860. 柠檬水找零…...
XYNU2024信安杯-REVERSE(复现)
前言 记录记录 1.Can_you_find_me? 签到题,秒了 2.ea_re 快速定位 int __cdecl main_0(int argc, const char **argv, const char **envp) {int v4; // [esp0h] [ebp-1A0h]const char **v5; // [esp4h] [ebp-19Ch]const char **v6; // [esp8h] [ebp-198h]char v7;…...