当前位置: 首页 > news >正文

使用 request 的 axios 状态码分析

request.interceptors.response.use(function(response){},function(error){})后端返回结果code===400不经过response,直接跳到error。

当后端返回状态码为 400 时直接进入 error 回调而不经过 response 回调,这是因为 axios 默认会将状态码不在 200 - 299 范围内的响应视为错误。

解决

1. 修改 validateStatus 配置


你可以通过修改 axios 实例的 validateStatus 配置,来改变对成功状态码的判断逻辑。

import axios from 'axios';

// 创建 axios 实例
const request = axios.create({
  // 修改 validateStatus 配置,允许 400 状态码进入 response 回调
  validateStatus: function (status) {
    return status >= 200 && status < 500; // 这里将成功状态码范围修改为 200 - 499
  }
});

// 添加响应拦截器
request.interceptors.response.use(
  function (response) {
    // 处理响应数据
    if (response.data.code === 400) {
      // 处理 code 为 400 的情况
      console.log('后端返回 code 为 400');
    }
    return response;
  },
  function (error) {
    // 处理错误
    console.error('请求出错:', error);
    return Promise.reject(error);
  }
);

export default request;

2. 在 error 回调中处理状态码 400


如果不想修改 validateStatus 配置,也可以在 error 回调中处理状态码为 400 的情况。

import axios from 'axios';

// 创建 axios 实例
const request = axios.create();

// 添加响应拦截器
request.interceptors.response.use(
  function (response) {
    // 处理成功响应
    return response;
  },
  function (error) {
    // 处理错误
    if (error.response && error.response.status === 400) {
      // 处理状态码为 400 的情况
      console.log('后端返回 code 为 400');
      // 可以在这里进行其他处理,如提示用户等
    }
    return Promise.reject(error);
  }
);

export default request;

总结


修改 validateStatus 配置:适用于你希望将更多状态码视为成功响应的情况,这样可以让这些状态码的响应进入 response 回调进行统一处理。
在 error 回调中处理:适用于你只想对特定状态码(如 400)进行特殊处理,而不改变 axios 对成功状态码的默认判断逻辑。
你可以根据实际需求选择合适的解决办法。 在使用 axios(推测你使用的 request 是 axios 实例)时,当后端返回状态码为 400 时直接进入 error 回调而不经过 response 回调,这是因为 axios 默认会将状态码不在 200 - 299 范围内的响应视为错误。下面为你详细分析可能的原因及解决办法。

相关文章:

  • 市场热点复盘20240319
  • 数据结构Api
  • 泛微e9 流程表单使用 显示属性联动 实现某个字段的显示与隐藏
  • 【愚公系列】《高效使用DeepSeek》017-知识点思维导图生成
  • 危化品经营单位考试:心理调适与知识巩固双管齐下​
  • 头部颤抖的预防措施
  • win10 如何用我的笔记本 接网线 远程控制 台式机
  • OpenNJet动态API设置accessLog开关,颠覆传统运维工作模式
  • “四预”驱动数字孪生水利:让智慧治水守护山河安澜
  • SIEMENS中集车辆PLM项目建设方案(96页PPT)(文末有下载方式)
  • excel文件有两列,循环读取文件两列赋值到字典列表。字典的有两个key,分别为question和answer。将最终结果输出到json文件
  • LCCI ESG 中英联合认证国际分析师适合的岗位
  • AUTOSAR_DoIP_Detailed
  • 计算机操作系统和进程
  • 基于java的ssm+JSP+MYSQL的高校四六级报名管理系统(含LW+PPT+源码+系统演示视频+安装说明)
  • Windows 11技巧:使用Powershell定义命令别名
  • 2025 年 AI 代码编辑器深度评测:Cursor Pro订阅与解锁自定义 AI 的无限潜能,实战案例全解析
  • 现代复古像素风品牌海报游戏排版设计装饰英文字体 Psygen — Modern Pixel Font
  • 再探C语言(1)
  • 如何利用iOS应用内事件提升订阅类应用表现?
  • 从孔雀尾巴到蒙娜丽莎,一个鸟类学博士眼中的“美”
  • 中办、国办印发《安全生产考核巡查办法》
  • 俄宣布停火三天,外交部:希望各方继续通过对话谈判解决危机
  • 港交所与香港证监会就“中概股回流意向”已与部分相关企业进行接触
  • 怒江州委常委、泸水市委书记余剑锋调任云南省委省直机关工委副书记
  • 企业取消“大小周”引热议,半月谈:不能将显性加班变为隐性加班