使用 request 的 axios 状态码分析

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

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

解决

1. 修改 validateStatus 配置

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

javascript 复制代码
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 的情况。

javascript 复制代码
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 范围内的响应视为错误。下面为你详细分析可能的原因及解决办法。

相关推荐
柠檬味的Cat几秒前
使用腾讯云COS作为WordPress图床的实践
前端·github·腾讯云
Hilaku3 分钟前
卷AI、卷算法、2026 年的前端工程师到底在卷什么?
前端·javascript·面试
非凡ghost5 分钟前
AIMP(音乐播放软件)
前端·windows·音视频·firefox
xiaotao1316 分钟前
Vite 完全学习指南
前端·vite·前端打包
军军君0120 分钟前
Three.js基础功能学习十五:智能黑板实现实例二
开发语言·前端·javascript·vue.js·3d·threejs·三维
IT枫斗者28 分钟前
构建具有执行功能的 AI Agent:基于工作记忆的任务规划与元认知监控架构
android·前端·vue.js·spring boot·后端·架构
hotlinhao29 分钟前
Nginx rewrite last 与 redirect 的区别——Vue history 模式短链接踩坑记录
前端·vue.js·nginx
ZC跨境爬虫32 分钟前
海南大学交友平台开发实战day7(实现核心匹配算法+解决JSON请求报错问题)
前端·python·算法·html·json
下北沢美食家35 分钟前
CSS面试题2
前端·css
weixin_4617694041 分钟前
npm create vue@latest 错误
前端·vue.js·npm