美文网首页
请求拦截器 与 响应拦截器(React)

请求拦截器 与 响应拦截器(React)

作者: 生命里那束光 | 来源:发表于2022-05-26 09:26 被阅读0次
前提:

请求拦截器和响应拦截器主要应用场景:请求网络接口

  • 请求拦截器:发送请求的时候,携带一些信息
  • 响应拦截器:接收到数据的时候,进行数据过滤、对状态码判断,进行对应的操作

封装在untils文件夹里面的封装网络请求的的request.js文件

// 创建axios实例
export const baseURL = 'http://geek.itheima.net/v1_0/'
const instance = axios.create({
  baseURL,
  timeout: 5000,
})

一、请求拦截器

  • 请求拦截器的作用是在请求发送前进行一些操作,例如在每个请求体里加上token,统一做了处理如果以后要改也非常容易。

代码实现(React)

/**
 * 保存token
 * @param {*} token
 * @returns
 */
export const setToken = (token) => localStorage.setItem(TOKEN_KEY, token)

/**
 * 获取token
 * @returns token
 */
export const getToken = () => localStorage.getItem(TOKEN_KEY)

// 配置拦截器
// 添加请求拦截器
instance.interceptors.request.use(
  function (config) {
    // 在发送请求之前做些什么,如果有token
    if (hasToken()) {
      config.headers.Authorization = `Bearer ${getToken()}`
    }
    return config
  },
  function (error) {
    // 对请求错误做些什么
    return Promise.reject(error)
  }
)

二、响应拦截器

  • 响应拦截器的作用是在接收到响应后进行一些操作
    • 例如在服务器返回登录状态失效,需要重新登录的时候,跳转到登录页。
    • 对接收到的数据进行处理筛选,只留下需要的数据
  • 响应拦截器也是一样如此,就是在请求结果返回后,先不直接导出,而是先对响应码等等进行处理,处理好后再导出给页面,如果将这个对响应码的处理过程抽出来,就成了所谓的响应拦截器。

代码实现(React)

/**
 * 移除token
 * @returns
 */
export const removeToken = () => localStorage.removeItem(TOKEN_KEY)

// 添加响应拦截器
instance.interceptors.response.use(
  function (response) {
    // 对响应数据做点什么
    return response.data
  },
  function (error) {
    // 对响应错误做点什么
    // 对token过期进行统一的处理
    if (!error.response) {
      // 如果error信息中没有response,网络超时导致
      message.error('网络繁忙,请稍后重试')
      return Promise.reject('网络繁忙,请稍后重试')
    }
    if (error.response.status === 401) {
      // 代表token过期了
      // 1. 删除token
      removeToken()
      // 2. 给提示消息
      message.warn('登录信息过期了', 1)
      // 3. 跳转到登录页
      // 怎么跳转到登录???
      // 难点:在非组件中,,,我们是无法使用 Redirect  也无法访问到history对象
      // window.location.href = '/login'
      history.push('/login')
    }
    return Promise.reject(error)
  }
)

三、页面中请求接口时

相关文章

  • 请求拦截器 与 响应拦截器(React)

    前提: 请求拦截器和响应拦截器主要应用场景:请求网络接口请求拦截器:发送请求的时候,携带一些信息响应拦截器:接收到...

  • 请求拦截器 与 响应拦截器(Vue)

    前提: 请求拦截器和响应拦截器主要应用场景:请求网络接口请求拦截器:发送请求的时候,携带一些信息响应拦截器:接收到...

  • 小程序添加fly配置

    添加请求拦截器 添加响应拦截器,响应拦截器会在then/catch处理之前执行 挂载原型

  • axios--拦截器(1)

    关于axios的拦截器是一个作用非常大,非常好用的东西。分为请求拦截器和响应拦截器两种。 请求拦截器响应拦截器 我...

  • axios安装与基本配置

    安装:$npm install axios --save get请求: post请求: 请求拦截器和响应拦截器

  • vue之axios篇 request拦截器的使用

    axios里面可以设置拦截器 ,可以在我们正式请求发送之前做一些事情拦截器分请求拦截器和响应拦截器首先我们看下请求...

  • axios 请求拦截器&响应拦截器

    一、 拦截器介绍 一般在使用axios时,会用到拦截器的功能,一般分为两种:请求拦截器、响应拦截器。 请求拦截器在...

  • axios使用详解

    文档 1. 拦截器 1.1 请求拦截器 基本格式 可以添加一些头部信息 1.2 响应拦截器 axios响应时,基本...

  • axios拦截器

    拦截器 在请求或响应被then或catch处理前拦截它们。 // 添加请求拦截器 axios.intercepto...

  • vue之axios篇 拦截器

    axios里面可以设置拦截器 ,可以在我们正式请求发送之前做一些事情拦截器分请求(request)拦截器和响应(r...

网友评论

      本文标题:请求拦截器 与 响应拦截器(React)

      本文链接:https://www.haomeiwen.com/subject/vrdyprtx.html