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

除了Axios,如何用fetch处理403错误?

使用 fetch API 处理 403 错误与使用 Axios 类似,但需要手动检查响应状态。以下是一些最佳实践和示例,展示如何在使用 fetch 时优雅地处理 403 错误。

1. 基本的 Fetch 请求

首先,您需要进行一个基本的 fetch 请求,并检查响应的状态码。

示例请求

fetch('/api/protected-resource')
  .then(response => {
    if (response.status === 403) {
      // 处理 403 错误
      handleForbidden();
      return;
    }
    if (!response.ok) {
      throw new Error('Network response was not ok');
    }
    return response.json();
  })
  .then(data => {
    // 处理成功的响应数据
    console.log(data);
  })
  .catch(error => {
    console.error('Fetch error:', error);
  });

2. 创建一个处理 403 错误的函数

可以将处理 403 错误的逻辑封装到一个函数中,以便在多个地方重用。

示例处理函数

function handleForbidden() {
  // 这里可以更新 Vuex 状态、导航到 403 页面等
  console.log("您没有权限访问此页面。");
  // 例如,导航到 403 页面
  window.location.href = '/forbidden'; // 或使用 Vue Router 进行导航
}

3. 使用 async/await

使用 async/await 可以使代码更简洁和易读。

示例使用 async/await

async function fetchProtectedResource() {
  try {
    const response = await fetch('/api/protected-resource');

    if (response.status === 403) {
      handleForbidden();
      return;
    }

    if (!response.ok) {
      throw new Error('Network response was not ok');
    }

    const data = await response.json();
    console.log(data);
  } catch (error) {
    console.error('Fetch error:', error);
  }
}

4. 在 Vue 组件中使用 Fetch

在 Vue 组件中,可以使用 fetch 进行 API 请求,并处理 403 错误。

示例 Vue 组件

<template>
  <div>
    <h1>Protected Resource</h1>
    <button @click="loadResource">加载资源</button>
    <p v-if="error">{{ error }}</p>
  </div>
</template>

<script>
export default {
  data() {
    return {
      error: null
    };
  },
  methods: {
    async loadResource() {
      this.error = null; // 重置错误状态
      try {
        const response = await fetch('/api/protected-resource');

        if (response.status === 403) {
          this.handleForbidden();
          return;
        }

        if (!response.ok) {
          throw new Error('Network response was not ok');
        }

        const data = await response.json();
        console.log(data); // 处理成功的响应数据
      } catch (err) {
        this.error = '发生错误: ' + err.message;
      }
    },
    handleForbidden() {
      this.error = '您没有权限访问此资源。';
      // 可以在这里导航到 403 页面
      // this.$router.push({ name: 'Forbidden' });
    }
  }
}
</script>

5. 处理全局错误

如果您需要在整个应用中处理 403 错误,可以创建一个全局的错误处理机制。

示例全局错误处理

在应用的入口文件中(如 main.js),您可以创建一个全局的 fetch 代理:

const originalFetch = window.fetch;

window.fetch = async (...args) => {
  const response = await originalFetch(...args);
  
  if (response.status === 403) {
    handleForbidden();
  }

  return response;
};

function handleForbidden() {
  console.log("您没有权限访问此页面。");
  // 例如,导航到 403 页面
  window.location.href = '/forbidden';
}

总结

使用 fetch 处理 403 错误需要手动检查响应状态,并根据需要进行处理。通过封装处理逻辑、使用 async/await 和在 Vue 组件中合理使用 fetch,您可以优雅地管理未授权访问。此外,创建全局的错误处理机制,可以进一步提升用户体验

相关文章:

  • 懒人美食帮(springboot论文源码调试讲解)
  • 【记录55】多个参数查询,无用参数不记查询
  • go 通过ssh连接linux golang.org/x/crypto/ssh
  • 网络安全设备防护原理 网络安全防护装置
  • WARNING: pip is configured with locations that require TLS/SSL
  • C语言的指针常量、常量指针、指针函数、函数指针的区别
  • 去中心化协作智能生态系统设计
  • 【Flink实战】Flink网络内存和托管内存
  • 可视化工具SciChart如何结合Deepseek快速创建一个React仪表板?
  • CT dicom 去除床板 去除床位,检查床去除
  • Java Web开发实战与项目——Spring Boot与Redis实现缓存管理
  • Unitree Project
  • 深度学习-119-Text2SQL之实现的三种技术途径
  • C语言程序实现shell命令的重定向符号功能
  • D-FINE模型详解及代码复现
  • 酒店旅游API:数据交互的隐形桥梁——以携程API为例
  • Jenkins 视图(View)
  • 蓝桥杯15 填空题
  • TensorFlow v2.16 Overview
  • JDK源码系列(一)Object
  • 媒体:多家国有大行存款利率即将迎来新一轮下调
  • 确诊前列腺癌后,拜登首次发声
  • 前4个月全国新建商品房销售面积降幅收窄,房地产库存和新开工有所改善
  • 家庭医生可提前5天预约三甲医院号源,上海常住人口签约率达45%,
  • 广东高州发生山体滑坡,造成2人遇难4人送医救治1人失联
  • “上海-日喀则”援藏入境旅游包机在沪首航