【错误记录/js】保存octet-stream为文件后数据错乱
目录
- 说在前面
- 场景
- 解决方式
- 其他
说在前面
- 后端:go、gin
- 浏览器:Microsoft Edge 120.0.2210.77 (正式版本) (64 位)
场景
- 前端通过点击按钮来下载一些文件,但是文件内容是一些非文件形式存储的二进制数据。

- 后端代码
r := gin.Default()r.Static("/home", "./public")r.GET("/down", func(c *gin.Context) {type A struct {B uint `json:"B"`C string `json:"C"`}a := &A{B: 746,C: "sjdfksdjlvsj",}fileName := "aaa"c.Header("Content-Type", "application/octet-stream")c.Header("Content-Disposition", "attachment; filename="+fileName)// c.Header("Content-Transfer-Encoding", "binary")c.Header("Cache-Control", "no-cache")var save bytes.Buffer// 使用gob的序列化进行测试enc := gob.NewEncoder(&save)enc.Encode(a)// 保存到本地用于对比file, err := os.OpenFile("test.txt", os.O_CREATE, 0)if err != nil {fmt.Println(err)return}defer file.Close()file.Write(save.Bytes())// 返回到前端c.Data(http.StatusOK, "application/octet-stream", save.Bytes()) }) r.Run() - js代码
function downloadBlob(data) {console.log([data])const anchor = document.createElement('a');document.body.appendChild(anchor);var url = window.URL.createObjectURL(new Blob([data]));anchor.href = url;anchor.download = "file.txt"anchor.click();document.body.removeChild(anchor); } function downloadFileBlob() {// 使用axios请求数据axios.get("/down").then((response) => {downloadBlob(response.data);}) } - 对比发现数据对不上(左:js保存 右:本地文件保存)

解决方式
- 尝试发现不需要使用axios,直接使用链接就行
function downloadFile() {const anchor = document.createElement('a');anchor.href = "/down";document.body.appendChild(anchor);anchor.click();document.body.removeChild(anchor);} - 结果一致了

其他
- 具体为什么会导致这种差异,查了一些资料,大概率是编码上的问题,后面有时间再详细查。
相关文章:
【错误记录/js】保存octet-stream为文件后数据错乱
目录 说在前面场景解决方式其他 说在前面 后端:go、gin浏览器:Microsoft Edge 120.0.2210.77 (正式版本) (64 位) 场景 前端通过点击按钮来下载一些文件,但是文件内容是一些非文件形式存储的二进制数据。 后端代码 r : gin.Default()r.Stat…...
sql_lab之sqli中的post注入
Post注入 用burpsuit抓包去做 Post第一关:(gxa5) 1.判断是否存在注入 username1or 11 #&password123&submit%E7%99%BB%E5%BD%95 有回显 username1or 12 #&password123&submit%E7%99%BB%E5%BD%95 没有回显 则证明存在sq…...
智能优化算法应用:基于白冠鸡算法3D无线传感器网络(WSN)覆盖优化 - 附代码
智能优化算法应用:基于白冠鸡算法3D无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用:基于白冠鸡算法3D无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.白冠鸡算法4.实验参数设定5.算法结果6.参考文…...
DETR++: Taming Your Multi-Scale Detection Transformer论文解读
文章目录 前言一、摘要二、引言三、相关研究四、模型方法1、Removing the Encoder方法2、Multi-Head方法3、Shifted Windows方法4、Bi-directional Feature Pyramid方法5、DETR方法 五、实验结果总结 前言 今天查看了一篇DETR论文,本想网络上找博客大概浏览一下&am…...
高级数据结构 <二叉搜索树>
本文已收录至《数据结构(C/C语言)》专栏! 作者:ARMCSKGT 目录 前言正文二叉搜索树的概念二叉搜索树的基本功能实现二叉搜索树的基本框架插入节点删除节点查找函数中序遍历函数析构函数和销毁函数(后序遍历销毁)拷贝构造和赋值重载(前序遍历创建)其他函数…...
蚂蚁集团5大开源项目获开放原子 “2023快速成长开源项目”
12月16日,在开放原子开源基金会主办的“2023开放原子开发者大会”上,蚂蚁集团主导开源的图数据库TuGraph、时序数据库CeresDB、隐私计算框架隐语SecretFlow、前端框架OpenSumi、数据域大模型开源框架DB-GPT入选“2023快速成长开源项目”。 (图…...
SpringBoot+JaywayJsonPath实现Json数据的DSL(按照指定节点表达式解析json获取指定数据)
场景 若依前后端分离版手把手教你本地搭建环境并运行项目: 若依前后端分离版手把手教你本地搭建环境并运行项目_前后端分离项目本地运行-CSDN博客 在上面搭建SpringBoot项目的基础上,并且在项目中引入fastjson、hutool等所需依赖后。 Jayway JsonPat…...
气压计LPS28DFW开发(2)----水压检测
气压计LPS28DFW开发.2--水压检测 概述视频教学样品申请完整代码下载水压计算设置速率和分辨率轮询读取数据测试结果 概述 本文将介绍如何使用 LPS28DFW 传感器来读取的压强数据,来估算水下深度,可以利用液体静压的原理。 最近在弄ST和瑞萨RA的课程&…...
设计模式之-装饰模式,快速掌握装饰模式,通俗易懂的讲解装饰模式以及它的使用场景
系列文章目录 设计模式之-6大设计原则简单易懂的理解以及它们的适用场景和代码示列 设计模式之-单列设计模式,5种单例设计模式使用场景以及它们的优缺点 设计模式之-3种常见的工厂模式简单工厂模式、工厂方法模式和抽象工厂模式,每一种模式的概念、使用…...
计算机网络个人小结
不同层的数据报的名称 应用层: data TCP层: segment IP 层: packet MAC层: frame MTU vs MSS: MTU:一个网络包的最大长度,以太网中一般为 1500 字节。 https://www.xiaolincoding.com/network/1_base/how_os_deal_network_package.html#linux-%E7%BD%91…...
酒店网站搭建的作用是什么
线上已经成为各行业商家增长破局的必要手段,传统酒店行业因信息扩展度不够,导致品牌难以传播、无法实现用户对酒店所有信息全面知悉,也无法实现在线预约及其它赋能用户消费的路径。 面对获客转化难题,很多酒店商家通过建立自营商…...
俄罗斯联邦税务局遭乌克兰入侵,数据库和副本被清空,政府数据安全不容忽视
俄罗斯联邦税务局遭乌克兰入侵,数据库和副本被清空,政府数据安全不容忽视 据相关报道,2023年12月12日,乌克兰国防情报局(GUR)称其成功入侵了俄罗斯联邦税务局(FNS)系统,并清除了该机构的数据库和…...
WPF组合控件TreeView+DataGrid之TreeView封装
(关注博主后,在“粉丝专栏”,可免费阅读此文) wpf的功能非常强大,很多控件都是原生的,但是要使用TreeViewDataGrid的组合,就需要我们自己去封装实现。 我们需要的效果如图所示&#x…...
redisson 哨兵模式配置
背景:项目redis由集群改为哨兵模式,漏洞扫描未授权访问漏洞(CNVD-2019-21763),要求对redis哨兵也设置密码,redisson依赖版本为3.11.5 spring-boot版本为2.1.13。 redisson依赖升级 <dependency>&l…...
免费的ChatGPT分享
免费的ChatGPT 以下是一些免费的ChatGPT平台和工具: 零声教学AI助手 零声教育内部使用的ChatGPT,提供智能对话和问题解答功能。 Ora.ai 一个可以自定义的AI聊天机器人,可以根据个人需求进行定制和训练。 ChatGPT 人工智能聊天机器人&a…...
C语言—每日选择题—Day54
指针相关博客 打响指针的第一枪:指针家族-CSDN博客 深入理解:指针变量的解引用 与 加法运算-CSDN博客 第一题 1. 存在int类型变量x,y,z,其对应值为x0x59,y0x39,z0x6E,则x * y z的值…...
先进制造身份治理现状洞察:从手动运维迈向自动化身份治理时代
在新一轮科技革命和产业变革的推动下,制造业正面临绿色化、智能化、服务化和定制化发展趋势。为顺应新技术革命及工业发展模式变化趋势,传统工业化理论需要进行修正和创新。其中,对工业化水平的判断标准从以三次产业比重标准为主回归到工业技…...
【密码学引论】密码协议
定义:两个或者两个以上参与者为了完成某一特定任务而采取的一系列执行步骤密码协议:Kerberos、IPSec、SSL、SET算法是低层次上的概念,而协议是高层次上的概念,协议建立在算法的基础上。所有密码协议都容易受中间人攻击,…...
利用快手的用户数据和精准营销提升电商平台用户转化率和销售额
一、快手用户数据的价值 快手作为国内领先的短视频平台,拥有庞大的用户群体和丰富的用户行为数据。这些数据包括用户的观看习惯、互动行为、兴趣偏好等,对于电商平台来说具有极高的商业价值。通过分析这些数据,电商平台可以深入了解用户需求…...
Linux根目录下默认目录作用
在Linux操作系统中,根目录(/)下的默认目录一般用于不同用途的文件存放和系统管理。以下是一些常见的默认目录及其用途: /bin:该目录存放系统的基本命令和可执行文件,如ls、cp、mv等。这些命令可供系统用户…...
硬件故障排查:从时序竞争到系统接地的深度调试实践
1. 从“无故障发现”到真相:一次硬盘子系统故障的深度追查在硬件开发的漫长职业生涯里,最让人头疼的往往不是那些板上钉钉、逻辑清晰的故障。真正折磨人的,是那些幽灵般的“无故障发现”问题。它们时隐时现,在测试台上一切正常&am…...
别再发.enl文件了!用EndNote X9的Compressed Library(.enlx)一键打包文献库,老板的旧版X8也能秒开
科研协作新姿势:EndNote文献库跨版本兼容全攻略 实验室里的小张刚把整理好的300篇参考文献库发给导师,第二天就被叫去办公室:"你这文件我打不开啊!"导师皱着眉头指着屏幕上EndNote X8的报错窗口。这种场景在科研协作中屡…...
从OOK到2ASK:二进制数字载波调制的入门实践与误码率分析
1. 从灯泡开关到数字通信:OOK调制初探 想象一下你站在房间门口,用开关控制灯泡向远处的朋友传递信息——亮表示"1",灭表示"0"。这就是OOK(通断键控)最直观的生活原型。作为二进制振幅键控(2ASK)家…...
使用Deno部署Gemini代理:实现OpenAI兼容与国内直连
1. 项目概述:一个为AI开发者准备的“直连”工具 如果你正在折腾各种AI编程助手,比如Cursor、Cline,或者喜欢用ChatBox、Cherry Studio这类客户端,那你大概率遇到过同一个头疼的问题:想用Google的Gemini模型࿰…...
全栈开发实战:基于Turborepo、Next.js与Expo的现代化启动套件深度解析
1. 项目概述:一个面向全栈开发者的现代化启动套件 如果你正在寻找一个能同时启动Web和移动应用开发,并且内置了AI能力、认证和数据库的“全家桶”式解决方案,那么你很可能已经听说过或正在寻找类似shipkit这样的项目。作为一个在Web和移动端开…...
AIGC率过高怎么降?8款高效降AI工具实测(附免费避坑指南)
不知道正在赶论文的你有没有遇到过这种糟心事:初稿熬了好几个通宵写完,送AIGC检测一出来满页标红,AI率直接飘红超标,比普通查重还让人头疼——毕竟很多学校对AI生成内容直接一票否决,不合格连答辩资格都拿不到。更气人…...
职场办公视觉设计入门:实用模板工具推荐
职场办公场景对视觉输出的要求正在逐步提升,无论是部门汇报的PPT,内部活动的宣传海报,还是公众号推文的首图,都需要具备基础的视觉质感。多数非设计岗的职场人没有系统学习过设计技能,对专业设计软件操作陌生ÿ…...
YOLO11涨点优化:训练技巧 | 基于EMA(指数滑动平均)与SWA(随机权重平均)双保险,刷榜最后一公里必备
写在前面 在目标检测竞赛和工业落地中,有一个令人头疼的现象:模型在COCO预训练权重上表现惊艳,但迁移到自己的数据集后,精度长期“趴窝”——涨不上去,也掉不下来。投入大量资源调参、改结构、加数据增强,mAP就是纹丝不动。这种“不涨点”现象已经成为许多算法工程师在冲…...
耳机音频测量技术:标准、方法与工程实践
1. 耳机音频测量技术概述在音频设备研发和质量控制领域,耳机性能的客观测量一直是个技术难点。与扬声器测量不同,耳机测量需要模拟人耳的真实声学环境,这就涉及到复杂的耦合腔体设计和标准化的测量方法。IEC 60268-7作为国际电工委员会发布的…...
Strassen多脉动阵列架构:矩阵乘法硬件加速新方案
1. Strassen多脉动阵列架构解析:当算法优化遇上硬件设计矩阵乘法作为计算机科学中最基础的运算之一,其性能直接影响着机器学习、图像处理等众多领域的计算效率。传统矩阵乘法的时间复杂度为O(n),而Strassen算法通过分治策略将这个复杂度降低到…...
