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

相关推荐
ZC跨境爬虫25 分钟前
跟着 MDN 学 HTML day_29:(动态构建与更新 DOM 树)
前端·javascript·ui·html·html5·媒体
编程技术手记31 分钟前
html table布局平衡
前端·html
huoyueyi41 分钟前
3D数字孪生项目 LCP 优化指南
前端·3d·几何学
菜鸟小芯1 小时前
【腾讯位置服务开发者征文大赛】校园美食雷达 —— 基于 CodeBuddy + 腾讯 LBS 开发实战
前端·美食
搜狐技术产品小编20231 小时前
深度解析与业务实战:将 screenshot-to-code 改造为支持 React + Ant Design 的前端利器
前端·javascript·react.js·前端框架·ecmascript
Rik1 小时前
Cursor Rules 深度玩法:从全局配置到项目级规则,让 AI 真正理解你的项目
前端·后端
weixin_471383031 小时前
set和map结构,减少O(n)复杂度
前端·javascript
hunteritself1 小时前
GPT Image2 + Seedance 2.0:3 小时从剧本到 AI 互动影游,深度实测复盘
前端·数据库·人工智能·深度学习·transformer
独秀不如众秀2 小时前
前端页面引擎协议:由浅入深——从 30 行到 vform3 的演化之路
前端
学网安的肆伍2 小时前
【044-WEB攻防篇】PHP应用&SQL盲注&布尔回显&延时判断&报错处理&增删改查方式
前端·sql·php