From b8b24896b32351b3a7aa68d8365f5e820aa18ea3 Mon Sep 17 00:00:00 2001
From: Mrx <18278715334@163.com>
Date: Mon, 2 Feb 2026 14:53:13 +0800
Subject: [PATCH] =?UTF-8?q?=E4=BD=A0=E7=9A=84=E6=8F=90=E4=BA=A4=E8=AF=B4?=
=?UTF-8?q?=E6=98=8E=EF=BC=9A=E5=B0=81=E7=A6=81=E5=8A=9F=E8=83=BD=E5=8F=8A?=
=?UTF-8?q?=E4=B8=8E=E8=BF=9C=E7=A8=8B=E5=90=88=E5=B9=B6?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/App.vue | 4 ++--
src/composables/useApiFetch.js | 37 +++++++++++++++++++++++++++-------
vite.config.js | 4 ++--
3 files changed, 34 insertions(+), 11 deletions(-)
diff --git a/src/App.vue b/src/App.vue
index ff1a85f..0b8c86c 100644
--- a/src/App.vue
+++ b/src/App.vue
@@ -7,7 +7,7 @@ import { useDialogStore } from "@/stores/dialogStore";
import { useAuthStore } from "@/stores/authStore";
import { useWeixinShare } from "@/composables/useWeixinShare";
import WechatOverlay from "@/components/WechatOverlay.vue";
-import MaintenanceDialog from "@/components/MaintenanceDialog.vue";
+// import MaintenanceDialog from "@/components/MaintenanceDialog.vue";
const router = useRouter();
const agentStore = useAgentStore();
@@ -210,7 +210,7 @@ const h5WeixinGetCode = () => {
-
+
diff --git a/src/composables/useApiFetch.js b/src/composables/useApiFetch.js
index 0e8c604..aa82e03 100644
--- a/src/composables/useApiFetch.js
+++ b/src/composables/useApiFetch.js
@@ -51,22 +51,34 @@ const useApiFetch = createFetch({
if (data.code !== 200) {
if (data.code === 100009) {
- // 改进的存储管理
+ // 用户不存在:清除并刷新
localStorage.removeItem('token')
localStorage.removeItem('refreshAfter')
localStorage.removeItem('accessExpire')
localStorage.removeItem('userInfo')
localStorage.removeItem('agentInfo')
- // 重置状态
const userStore = useUserStore();
const agentStore = useAgentStore();
userStore.resetUser()
agentStore.resetAgent()
location.reload()
-
}
- if (data.code !== 200002 && data.code !== 200003 && data.code !== 200004 && data.code !== 100009) {
+ if (data.code === 100011) {
+ // 账号已被封禁:提示并跳转登录
+ showToast({ message: data.msg || "账号已被封禁" });
+ localStorage.removeItem('token')
+ localStorage.removeItem('refreshAfter')
+ localStorage.removeItem('accessExpire')
+ localStorage.removeItem('userInfo')
+ localStorage.removeItem('agentInfo')
+ const userStore = useUserStore();
+ const agentStore = useAgentStore();
+ userStore.resetUser()
+ agentStore.resetAgent()
+ router.replace("/login");
+ }
+ if (data.code !== 200002 && data.code !== 200003 && data.code !== 200004 && data.code !== 100009 && data.code !== 100011) {
showToast({ message: data.msg });
}
}
@@ -75,12 +87,23 @@ const useApiFetch = createFetch({
async onFetchError({ error, response }) {
console.log("error", error);
closeToast();
- if (response.status === 401) {
- // 清除本地存储的 token
+ if (response?.status === 401) {
localStorage.removeItem("token");
localStorage.removeItem('refreshAfter')
localStorage.removeItem('accessExpire')
- // 跳转到登录页
+ router.replace("/login");
+ } else if (response?.status === 403) {
+ // 账号已被封禁
+ showToast({ message: "账号已被封禁" });
+ localStorage.removeItem("token");
+ localStorage.removeItem('refreshAfter')
+ localStorage.removeItem('accessExpire')
+ localStorage.removeItem('userInfo')
+ localStorage.removeItem('agentInfo')
+ const userStore = useUserStore();
+ const agentStore = useAgentStore();
+ userStore.resetUser()
+ agentStore.resetAgent()
router.replace("/login");
} else {
if (typeof error === "string") {
diff --git a/vite.config.js b/vite.config.js
index d0ebfb0..4cf83c2 100644
--- a/vite.config.js
+++ b/vite.config.js
@@ -15,8 +15,8 @@ export default defineConfig({
strictPort: true, // 如果端口被占用则抛出错误而不是使用下一个可用端口
proxy: {
"/api/v1": {
- // target: "http://127.0.0.1:8888", // 本地接口地址
- target: "https://www.tianyuandb.com", // 本地接口地址
+ target: "http://127.0.0.1:8888", // 本地接口地址
+ // target: "https://www.tianyuandb.com", // 本地接口地址
changeOrigin: true,
},
},