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

除了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,您可以优雅地管理未授权访问。此外,创建全局的错误处理机制,可以进一步提升用户体验


http://www.kler.cn/a/560851.html

相关文章:

  • Linux故障排查和性能优化面试题及参考答案
  • MybatisPlus-插件功能-分页插件基本用法
  • 2024前端性能优化终极指南:从加载到渲染的完整解决方案
  • 谷歌浏览器(Google Chrome)扩展程序的安装路径(插件的安装路径)
  • 如何在VMware虚拟机的window10系统中安装网易mumu模拟器
  • angular表格排序分页
  • java 入门面试题
  • 对鸿蒙 中 对象的理解
  • SQL注入实战指南:sqli-labs全关卡通关详解与技巧总结
  • [java基础-JVM篇]1_JVM自动内存管理
  • js中的await与async的使用
  • 永洪科技旗下BI产品,成功入选“金融信创优秀解决方案“
  • redis添加密码
  • JavaAPI(lambda表达式、流式编程)
  • 4-知识图谱的抽取与构建-4_2实体识别与分类
  • CSS实现图片缺角效果
  • 如何查找 UBuntu的 arm版本
  • 大数据AI一体化开发再加速:DataWorks 支持GPU类型资源
  • 基于Springboot医院预约挂号小程序系统【附源码】
  • 2025:人工智能重构人类文明的新纪元