返回流类型接口的错误信息处理

news2024/11/26 21:31:54

返回流类型接口的错误信息处理

    • 前言
    • axios拦截器src/utils/request.ts
    • 对应接口

前言

返回流类型接口需要在响应成功回调里拦截,且该接口的status始终是200,尽管后端返回的code可能是非2xx,因此返回流类型的接口,其错误信息需要单独处理。

axios拦截器src/utils/request.ts

import axios, { type AxiosResponse } from 'axios'
import { ElMessage } from 'element-plus'
import Nprogress from 'nprogress'
import 'nprogress/nprogress.css'
import { getToken } from '@/utils/token'
import router from '@/router/index'
import { environment } from '@/evn.config'

const service = axios.create({
	baseURL: environment.VITE_APP_BASE_URL.includes('http')
		? environment.VITE_APP_BASE_URL
		: window.location.origin,
})

// 不需要token
const whiteList = ['/auth/oauth/token', '/register']

service.interceptors.request.use(
	(config) => {
		Nprogress.start()
		const unneededToken = whiteList.includes(config.url as string)
		if (!unneededToken) {
			const token = getToken()
			if (token && Object.getOwnPropertyNames(token).length) {
				// eslint-disable-next-line no-param-reassign
				config.headers.Authorization = `Bearer ${token.access_token}`
			}
		}

		return config
	},
	(err) => Promise.reject(err)
)

service.interceptors.response.use(
	(response: AxiosResponse) => {
		// isNoAccess = 0
		Nprogress.done()
		const { config, data, status, headers } = response
		console.log(response, config, data, status, headers, 'response-success')
		// 下载和预览
		if (
			config.url?.includes('downloadBatch') ||
			config.url?.includes('previewUrl')
		) {
			let fileName = ''
			if (headers['content-disposition']) {
				const arr = headers['content-disposition'].split(';')
				// eslint-disable-next-line no-restricted-syntax
				for (const item of arr) {
					if (item.search('filename') !== -1) {
						const arr1 = item.split('=')
						fileName = decodeURIComponent(arr1[arr1.length - 1])
						break
					}
				}
			} else {
				const fileReader: any = new FileReader()
				fileReader.readAsText(data, 'utf-8')
				fileReader.onload = () => {
					const result = JSON.parse(fileReader.result as string)
					// 错误提示信息,根据接口返回内容
					ElMessage.error(result?.message)
				}
			}
			return {
				data: {
					data,
					fileName,
				},
			}
		}

		if (status !== 200) {
			ElMessage.error({
				message: data.message,
				duration: 4000,
			})
			return Promise.reject(response)
		}

		// 流接口返回错误处理
		// if (!data.code && data.type === 'application/json') {
		// 	const fileReader = new FileReader()
		// 	fileReader.readAsText(data, 'utf-8')
		// 	fileReader.onload = () => {
		// 		const result = JSON.parse(fileReader.result as string)
		// 		ElMessage.error(result.message)
		// 	}
		// 	return null
		// }
		if (!data.success && data.code) {
			ElMessage.error({
				message: data.message,
				duration: 4000,
			})
		}

		return data
	},

	(error) => {
		Nprogress.done()
		console.log(error, 'response-error')
		if (error.response?.data.code && error.response?.data.code === '2007') {
			// 手动点击退出登录时,系统token过期 不提示信息
			if (error.response.config.url !== '/system/user/userLogout') {
				ElMessage.error('登录状态过期,请重新登录')
			}

			const url = router.resolve({
				path: '/middleBackLogin',
				query: {
					loginKey: 'tokenNoAccess',
				},
			})
			window.open(url.href, '_self')
		} else {
			ElMessage.error({
				message: error.message,
				duration: 4000,
			})
			if (error.code === 'ERR_NETWORK') {
				// 网络问题  强制清除缓存
				localStorage.clear()
				// 页面刷新
				window.location.reload()
			}
		}
		return Promise.reject(error)
	}
)

export default service

在这里插入图片描述

对应接口

在这里插入图片描述

import request from '@/utils/request'
import type { AxiosResponse } from 'axios'
import qs from 'qs'


/**
 * 预览申请
 * @returns
 */
export function previewUrl(id: number | string): Promise<AxiosResponse> {
	return request({
		url: `/datawarehouse-api/resourceApply/previewUrl/${id}`,
		responseType: 'blob', // 因为是流文件,所以要指定blob类型   这里响应blob,axios拦截器是无法拦截接口报错的msg的
		method: 'get',
	})
}

/**
 * 下载申请
 * @returns
 */
export function downloadBatch(params = {}): Promise<AxiosResponse> {
	return request({
		url: '/datawarehouse-api/resourceApply/downloadBatch',
		responseType: 'blob', // 因为是流文件,所以要指定blob类型
		method: 'get',
		params,
		// paramsSerializer: get请求,处理数组参数
		// 传的是:
			// ids: [xxx,xxx]
		// 负载为:
			// ids: xxx    
			// ids: xxx
		paramsSerializer(params) {
			return qs.stringify(params, { arrayFormat: 'repeat' })
		},
	})
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2246174.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

用宏实现简单的计算器

大家好&#xff0c;那么经过我们前面几期的学习&#xff0c;我们对宏有了一定的了解&#xff0c;那么我们今天就来试试实现一个简单的加减乘除运算。 我们的思路是使用三目操作符来分别进行加减和乘除的运算&#xff0c;然后用if判断来”进入相关的判断体进而来进行计算。当然…

WEB攻防-通用漏洞文件上传js验证mimeuser.ini语言特性

知识点&#xff1a; 1、文件上传-前端验证 2、文件上传-黑白名单 3、文件上传-user.ini妙用 4、文件上传-php语言特性 详细点&#xff1a; 1、检测层面&#xff1a;前端&#xff0c;后端等 2、检测内容&#xff1a;文件头&#xff0c;完整型&#xff0c;二次渲染等 3、检…

《Vue零基础教程》(3)创建第一个应用案例

1 应用实例 参考官方文档 https://cn.vuejs.org/api/application.html#create-app 示例 const {createApp} Vue// 通过createApp创建一个应用实例 const app createApp({/* 选项 */ }) console.log(app) 分析打印结果, 可知 应用实例是一个对象没有_开头的是公开属性/方…

复合瓦片切片集集合数量与性能关系验证

作者&#xff1a;lzzzz Sci瓦片聚合性能分析 需要聚合的图层越多&#xff0c;性能越低&#xff0c;目前测试以每个瓦片仅包含一个矢量面数据为例&#xff1a; sci数量 服务拉起耗时 前端加载&#xff08;单瓦片&#xff09; 100 10s 500ms 1000 5min 3s 10000 1hour …

大数据-231 离线数仓 - DWS 层、ADS 层的创建 Hive 执行脚本

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; Java篇开始了&#xff01; 目前开始更新 MyBatis&#xff0c;一起深入浅出&#xff01; 目前已经更新到了&#xff1a; Hadoop&#xff0…

摄影:相机控色

摄影&#xff1a;相机控色 白平衡&#xff08;White Balance&#xff09;白平衡的作用&#xff1a; 白平衡的使用环境色温下相机色温下总结 白平衡偏移与包围白平衡包围 影调 白平衡&#xff08;White Balance&#xff09; 人眼看到的白色&#xff1a;会自动适应环境光线。 相…

性能监控利器:Ubuntu 22.04 上的 Zabbix 安装与配置指南

简介 今天我们来聊聊如何在 Ubuntu 22.04 上安装和配置 Zabbix。我们会用到 PostgreSQL 作为数据库后端&#xff0c;Nginx 作为 Web 服务器&#xff0c;并用 Let’s Encrypt SSL 证书来保驾护航。 什么是 Zabbix&#xff1f; Zabbix 是一个开源的网络监控和管理解决方案&…

队列基本实现

模板 int queue[10010]; int hh1,tt0; void push1(int x) {queue[tt]x; } void pop1() {if(hh>tt){cout<<"ERR_CANNOT_POP"<<endl;}else{hh;} } int query1() {if(hh>tt){cout<<"ERR_CANNOT_QUERY"<<endl;}return queue[hh…

【ArcGISPro】使用AI模型提取要素-提取车辆(目标识别)

示例数据下载 栅格数据从网上随便找一个带有车辆的栅格数据 f094a6b1e205cd4d30a2e0f816f0c6af.jpg (1200799) (588ku.com) 添加数据

GitLab|数据迁移

注意&#xff1a;新服务器GitLab版本需和旧版本一致 在旧服务器执行命令进行数据备份 gitlab-rake gitlab:backup:create 备份数据存储在 /var/opt/gitlab/backups/ 将备份数据传输到新服务器的/var/opt/gitlab/backups/下&#xff0c;并修改文件权限&#xff08;下载前和上传…

UE5 5.1.1创建C++项目,显示error C4668和error C4067的解决方法

因为工作要求&#xff0c;没法使用最新 5.5版本的ue5 而是要用ue5.1和5.2版本。 但是我在安装下载了visual studio2022后&#xff0c;使用 ue5.1编辑器 创建C项目&#xff0c;爆出如下错误。 error C4668: ?????__has_feature?????ΪԤ?????꣬???0????…

网络安全概论

一、 网络安全是一个综合性的技术。在Internet这样的环境中&#xff0c;其本身的目的就是为了提供一种开放式的交互环境&#xff0c;但是为了保护一些秘密信息&#xff0c;网络安全成为了在开放网络环境中必要的技术之一。网络安全技术是随着网络技术的进步逐步发展的。 网络安…

51单片机基础01 单片机最小系统

目录 一、什么是51单片机 二、51单片机的引脚介绍 1、VCC GND 2、XTAL1 2 3、RST 4、EA 5、PSEN 6、ALE 7、RXD、TXD 8、INT0、INT1 9、T0、T1 10、MOSI、MISO、SCK 11、WR、RD 12、通用IO P0 13、通用IO P1 14、通用IO P2 三、51单片机的最小系统 1、供电与…

DASCTF 2024 10月 Reverse 完成笔记 附题目

题目链接: https://github.com/Airrcat/long_long/tree/main/DASCTF_2024_10 ezre 查PE 32位无壳 开始分析 看起来很像加壳了 字符串未有暴露信息&#xff0c;但是段中有一个themida 发现是一个壳&#xff0c;直接去找脱壳机 一些脱壳工具&#xff08;Magicmida)是…

JavaScript 中 arguments、类数组与数组的深入解析

博客主页&#xff1a; [小ᶻZ࿆] 本文专栏: 前端 文章目录 &#x1f4af;前言&#x1f4af;什么是 arguments 对象2.1 arguments 的定义2.2 arguments 的特性2.3 使用场景 &#x1f4af;深入了解 arguments 的结构3.1 arguments 的内部结构arguments 的关键属性 3.2 类数组…

Kafka 工作流程解析:从 Broker 工作原理、节点的服役、退役、副本的生成到数据存储与读写优化

Kafka&#xff1a;分布式消息系统的核心原理与安装部署-CSDN博客 自定义 Kafka 脚本 kf-use.sh 的解析与功能与应用示例-CSDN博客 Kafka 生产者全面解析&#xff1a;从基础原理到高级实践-CSDN博客 Kafka 生产者优化与数据处理经验-CSDN博客 Kafka 工作流程解析&#xff1a…

数位之和c++

题目描述 小杨有 n个正整数&#xff0c;他认为一个正整数是美丽数字当且仅当该正整数每一位数字的总和是 7 的倍数。 小杨想请你编写一个程序判断 n 个正整数哪些是美丽数字。 输入 第一行包含一个正整数 n&#xff0c;代表正整数个数。 之后n 行&#xff0c;每行包含一个…

同三维T4000S系列高清SDI字符叠加器

同三维T4000S系列高清SDI字符叠加器 两个型号&#xff1a; 同三维T4000S-2U (2U机箱&#xff0c;可插1-16张叠加模块) 同三维T4000S1 &#xff08;单路&#xff09; 产品简介 “HD-SDI字符叠加器”可在HD-SDI视频图象信号上叠加日期、时间及中英文字符信息。广泛用于安防监…

重生之我在学环境变量

环境变量 基本概念 环境变量(environment variables)一般是指在操作系统中用来指定操作系统运行环境的一些参数如&#xff1a;我们在编写C/C代码的时候&#xff0c;在链接的时候&#xff0c;从来不知道我们的所链接的动态静态库在哪里&#xff0c;但 是照样可以链接成功&#…

Flink学习连载文章4-flink中的各种转换操作

首先&#xff0c;先搞一个模板代码&#xff0c;方便后面的操作 #if (${PACKAGE_NAME} && ${PACKAGE_NAME} ! "")package ${PACKAGE_NAME};#end #parse("File Header.java") import org.apache.flink.streaming.api.environment.StreamExecutionEnv…