对接后端download接口报未知异常错误

embedded/2024/9/24 4:19:21/

你一定遇到过这种情况,在一个项目中下载功能明明好好的,下载接口调用方法与前端调用方法封装的好好的,可是换了一个接口,竟然搞罢工了,类似下面这样的,你会不会无从下手,不知道该怎么办呢?接下来我们就来说说这个问题。
在这里插入图片描述
一般接口报错主要有两个原因

  1. 后端接口问题
  2. 前端传参问题

首先要搞清楚是不是接口问题,可以在后端给出的接口文档调试页面进行调试,如果正常,那么大概率可以排除接口问题。比如像下面这样调用测试文档后返回了流数据,说明接口是正常的,那大概率是前端的问题了。
在这里插入图片描述
在前端开发中,调用API接口是常见的操作之一。正确地配置请求头(headers)和响应类型(responseType)对于确保请求的成功至关重要。下面详细解释这两个属性的设置及其作用。

Headers 设置

headers 是请求的一部分,它包含了客户端和服务端之间通信所需的信息,比如内容类型、认证信息等。在HTTP请求中,这些头部信息用于告诉服务器关于请求的一些元数据。

  • Content-Type: 这个头部字段用来描述请求体的格式。常见的值有:
    • application/json: 表示请求体是一个JSON对象。
    • application/x-www-form-urlencoded: 表示请求体是一个URL编码过的表单。
    • multipart/form-data: 通常用于上传文件时,因为文件数据不能简单地编码为字符串。

例如,Content-Type 被设置为 application/x-www-form-urlencoded,这意味着如果请求体中有数据的话,应该以URL编码的形式发送。

Response Type 设置

responseType 是一个选项,用于指定期望的响应类型。默认情况下,大多数库如axios会自动解析响应为JSON对象。但是,有时候我们需要直接处理原始的响应数据,这时就需要设置responseType了。

  • arraybuffer: 响应数据会被转换成ArrayBuffer。
  • blob: 响应数据将会是一个Blob对象,适用于处理文件或多媒体数据。
  • document: 当响应内容为HTML或XML文档时使用。
  • json: 自动解析为JSON对象。
  • text: 响应数据将被视为纯文本。

例如,responseType 被设置为 blob,这意味着服务端返回的数据将作为二进制数据处理,而不是尝试解析为JSON。这对于下载文件尤其有用,因为文件通常是以二进制形式传输的。

示例

假设我们使用axios库来发送一个GET请求,并且我们知道响应将是一个文件,我们可以这样设置:

javascript">import axios from 'axios';axios.get('/api/download', {headers: {'Content-Type': 'application/x-www-form-urlencoded',},responseType: 'blob'
})
.then(response => {// response.data 是一个 Blob 对象const blob = new Blob([response.data]);// 保存文件到本地saveAs(blob, 'example.pdf');
})
.catch(error => {console.error('Error downloading the file:', error);
});

在这个例子中,我们指定了请求头Content-Typeapplication/x-www-form-urlencoded,并且设置了responseTypeblob,以便正确处理文件下载。

总之,正确配置headersresponseType可以帮助你更好地控制请求和响应的处理方式,确保数据能够按照预期的方式进行交互。

注意,saveAs方法来自 file-saver库的一个方法,主要目的是接收一个Blob对象或ArrayBuffer,并将其保存为本地文件。这对于从Web应用中下载文件特别有用,例如从服务器获取的数据、生成的PDF文件、图像等。

那么报错了,如何解决呢,我的解决方法是将前端调用报错接口与后端调用正常的接口进行比较,看看headers配置是否一致,参数传递是否一致,请求方法是否一致
在这里插入图片描述

我这次报错是因为headersresponseType设置和后端接口不一致造成,修改一致后就OK了!


http://www.ppmy.cn/embedded/109937.html

相关文章

3.【Java开发手册】| 编程规约(二)

这里我就列出一些我认为应当遵守的,并且添加一些我自己在工作中的一些感受,如果照着文档抄,那完全变成练习打字了,浪费读者时间,如果你也认同我的看法,或者和我有类似感受,可以点个关注&#xf…

CATH数据库数据下载

CATH数据库提供了多种类型的数据供用户下载,涵盖了蛋白质的结构域分类、同源性分析、功能注释等方面。以下是CATH数据库提供的一些主要数据类型及其解释: http://www.cathdb.info/download 1. 分类数据(Classification Data) 文件…

Kubernetes

1、概念 希腊语,舵手、飞行员的意思 k8s可以理解成负责自动化运维管理多个容器化的应用集群。容器编排框架的工具,是谷歌基于go语言开发的 2、作用 用于自动部署、扩展、管理容器化部署的应用程序,是(半)开源的 k…

Vscode——调试时,修改变量值

第一步:点击变量,鼠标右键 第二步:点击 设置值

“深入解析:MySQL半同步复制的配置指南与实践技巧“

本次配置是在已搭建好主从复制的架构中进行配置 配置环境 操作系统 master节点 slave节点 centos7 8.0.37 8.0.37 配置半同步复制 配置master 安装master半同步复制插件 INSTALL PLUGIN rpl_semi_sync_source SONAME semisync_source.so; 在MySQL的配置文件中添加配置…

前端开发中 em/px/rem/vh/vw区别

传统的项目开发中,我们只会用到px、%、em这几个单位,它可以适用于大部分的项目开发,且拥有比较良好的兼容性从CSS3开始,浏览器对计量单位的支持又提升到了另外一个境界,新增了rem、vh、vw、vm等一些新的计量单位利用这…

命令模式(Command Pattern)

命令模式(Command Pattern)是一种行为设计模式,它将一个请求封装为一个对象,从而使你可以使用不同的请求、队列或日志来参数化对象。命令模式让你可以在不修改调用对象的情况下将请求排队、记录日志或撤销操作。 核心思想&#x…

利用深度学习实现验证码识别-4-ResNet18+imagecaptcha

在当今的数字化世界中,验证码(CAPTCHA)是保护网站免受自动化攻击的重要工具。然而,对于用户来说,验证码有时可能会成为一种烦恼。为了解决这个问题,我们可以利用深度学习技术来自动识别验证码,从…