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

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

1. 基本的 Fetch 请求

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

示例请求

javascript 复制代码
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 错误的逻辑封装到一个函数中,以便在多个地方重用。

示例处理函数

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

3. 使用 async/await

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

示例使用 async/await

javascript 复制代码
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 组件

html 复制代码
<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 代理:

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

相关推荐
Fighting_p13 分钟前
【面试 - el-select问题及解决】wujie 微前端下子系统 el-select 多选 filterable 过滤失效
前端
吃口巧乐兹14 分钟前
AI 全栈时代,为什么要服务端使用 NestJs
前端
yingyima19 分钟前
Redis 延迟任务队列:凌晨3点服务器报警的救星
前端
weiggle21 分钟前
第三篇:可组合函数(Composable)——Compose 的基石
android·前端
前端环境观察室22 分钟前
别只看 task success:AI Agent 浏览器自动化真正要补的是环境证据链
前端·后端
huakoh23 分钟前
LangChain 实战:用混合检索啃下 1000 页 PDF,搭一个长文档问答 Agent
前端
Dazer00733 分钟前
Edge 浏览器绕过 HTTPS 证书错误
前端·https·edge
元让_vincent39 分钟前
Spark 2.0:面向 Web 的 3DGS 可视化与大场景渲染平台详解
前端·3d·spark·渲染·轻量化·3dgs·lod
KaMeidebaby1 小时前
卡梅德生物技术快报|酵母双杂交 cDNA 文库构建与蛋白互作筛选流程
服务器·前端·数据库·人工智能·算法
沐风___1 小时前
App 上架之后:如何看数据、获取用户与持续迭代产品
服务器·前端·数据库