首页 > 解决方案 > 被拒绝的 HTTP 承诺没有命中 catch 块

问题描述

我使用 VueJs(和 Vuex)和 Axios 来与 Express Api 通信。我可以删除我自己的使用服务的用户帐户

import api from '@/services/api.js';

export default {
  deleteAccount: () => api().delete('/users')
};

实例api在哪里。axios我不需要传入用户 ID,因为 api 通过token识别用户。

在我的设置视图中,我可以使用此服务

<script>
import { mapActions } from 'vuex';

import UserService from '@/services/users'; 

export default {
  name: 'Settings',
  methods: {
    ...mapActions('alert', [
      'showSuccessAlert',
      'showErrorAlert'
    ])
    deleteAccount: async function() {
      try {
        await UserService.deleteAccount();

        this.showSuccessAlert({ message: 'Account was deleted successfully' });
        // other stuff
      } catch (error) {
        this.showErrorAlert({ message: error.message });
      }
    }
  }
};
</script>

打电话UserService.deleteAccount()给我一个未决的承诺。使用await返回给我的 api 响应。

目前,api 总是返回 a500用于测试目的。我想,如果 Promise 被拒绝,代码总是会直接跳到 catch 块中。在这里,代码返回一个被拒绝的 Promise(并将“内部服务器错误”写入控制台,但传递并显示成功警报/从不执行 catch 块中的代码。

代码有什么问题?我误解了承诺吗?


更新

我的 axios 实例

import axios from 'axios';

import TokensService from '@/services/tokens.js';
import store from '@/store/store.js';

function getTokenString() {
  return `Bearer ${TokensService.getToken()}`;
}

export default () => {
  const instance = axios.create({
    baseURL: 'http://localhost:3000/',
    headers: {
      'Content-Type': 'application/json',
      Authorization: getTokenString(),
    },
  });

  instance.interceptors.request.use((config) => {
    config.headers.Authorization = getTokenString();
    return config;
  }, (err) => Promise.reject(err));

  instance.interceptors.response.use((res) => res, (err) => {
    if (err.response.status === 401) {
      store.dispatch('authentication/destroySession');
      store.dispatch('alert/showErrorAlert', { message: err.message });
    }

    return err;
  });

  return instance;
};

调用api().delete()是一样的axios.delete('http://localhost:3000/users')

标签: javascriptvue.jsaxios

解决方案


尝试在这里返回一个被拒绝的承诺

  instance.interceptors.response.use((res) => res, (err) => {
    if (err.response.status === 401) {
      store.dispatch('authentication/destroySession');
      store.dispatch('alert/showErrorAlert', { message: err.message });
    }

    return Promise.reject(err);
  });

根据示例https://github.com/axios/axios#interceptors


推荐阅读