checkStatus.ts 1.66 KB
import type { ErrorMessageMode } from '/#/external/axios';
import { useUserStoreWithOut } from '@/store/external/module/user';
import { useI18n } from 'vue-i18n';
import { useMessage } from 'naive-ui';

const { error } = useMessage()
export function checkStatus(
  status: number,
  msg: string,
  errorMessageMode: ErrorMessageMode = 'message'
): void {
  const { t } = useI18n();
  const userStore = useUserStoreWithOut();
  let errMessage = msg;
  switch (status) {
    case 400:
      errMessage = `${msg}`;
      break;
    // 401: Not logged in
    // Jump to the login page if not logged in, and carry the path of the current page
    // Return to the current page after successful login. This step needs to be operated on the login page.
    case 401:
      errMessage = '';
      userStore.logout()
      break;
    case 403:
      errMessage = '未授权';
      break;
    // 404请求不存在
    case 404:
      errMessage = '未找到该资源!';
      break;
    case 405:
      errMessage = '网络请求错误,请求方法未允许!';
      break;
    case 408:
      errMessage = '网络请求超时!';
      break;
    case 500:
      errMessage = '服务器错误,请联系管理员!';
      break;
    case 501:
      errMessage = '网络未实现!';
      break;
    case 502:
      errMessage = '网络错误!';
      break;
    case 503:
      errMessage = '服务不可用,服务器暂时过载或维护!';
      break;
    case 504:
      errMessage = '网络超时!';
      break;
    case 505:
      errMessage = 'http版本不支持该请求!';
      break;
    default:
  }
  if (errMessage) {
    if (errorMessageMode === 'message') {
      error(errMessage);
    }
  }
}