diff --git a/src/App.vue b/src/App.vue
index 4076c47..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();
@@ -209,7 +209,8 @@ const h5WeixinGetCode = () => {
-
+
+
diff --git a/src/components/Payment.vue b/src/components/Payment.vue
index de93254..95ec414 100644
--- a/src/components/Payment.vue
+++ b/src/components/Payment.vue
@@ -151,61 +151,76 @@ const router = useRouter();
const discountPrice = ref(false); // 是否应用折扣
async function getPayment() {
- const { data, error } = await useApiFetch("/pay/payment")
- .post({
- id: props.id,
- pay_method: selectedPaymentMethod.value,
- pay_type: props.type,
- })
- .json();
+ showConfirmDialog({
+ title: "重要安全声明",
+ message: `为保障您的个人信息与资金安全,请您务必知悉以下事项:
- if (data.value && !error.value) {
- const prepayId = data.value.data.prepay_id;
- const orderNoFromResp = data.value.data.order_no;
+关于平台业务:本平台官方服务仅限于大数据报告查询,不涉及也从未开展"央行征信修复"、"贷款办理"或"征信洗白"等相关业务。请注意,本平台出具的报告仅供决策参考,不可作为任何官方征信凭证或贷款依据。
- // 开发环境测试支付:仅当用户选择「开发环境测试支付」时后端才返回 test_payment_success
- // 若选择支付宝/微信却收到此值,说明后端异常,不跳转、直接报错
- if (prepayId === "test_payment_success") {
- if (selectedPaymentMethod.value === "alipay" || selectedPaymentMethod.value === "wechat") {
- showToast({ message: "支付参数异常,请重试", type: "fail" });
- return;
+关于诈骗警示:任何自称与本平台合作,或以"内部渠道"、"百分百包下款"、"修复征信"等为由,诱导您进行支付的行为,均属欺诈。请您切勿相信,谨慎对待任何支付要求。
+
+关于安全提示:请您时刻保持警惕,妥善保管个人敏感信息。如遇任何索款要求或可疑承诺,请务必首先通过我平台官方公布的联系方式进行核实,切勿轻信他人。`,
+ })
+ .then(async () => {
+ const { data, error } = await useApiFetch("/pay/payment")
+ .post({
+ id: props.id,
+ pay_method: selectedPaymentMethod.value,
+ pay_type: props.type,
+ })
+ .json();
+
+ if (data.value && !error.value) {
+ const prepayId = data.value.data.prepay_id;
+ const orderNoFromResp = data.value.data.order_no;
+
+ // 开发环境测试支付:仅当用户选择「开发环境测试支付」时后端才返回 test_payment_success
+ // 若选择支付宝/微信却收到此值,说明后端异常,不跳转、直接报错
+ if (prepayId === "test_payment_success") {
+ if (selectedPaymentMethod.value === "alipay" || selectedPaymentMethod.value === "wechat") {
+ showToast({ message: "支付参数异常,请重试", type: "fail" });
+ return;
+ }
+ show.value = false;
+ router.push({
+ path: "/payment/result",
+ query: { orderNo: orderNoFromResp },
+ });
+ return;
+ }
+
+ if (selectedPaymentMethod.value === "alipay") {
+ orderNo.value = orderNoFromResp;
+ // 存储订单ID以便支付宝返回时获取
+ const prepayUrl = prepayId;
+ const paymentForm = document.createElement("form");
+ paymentForm.method = "POST";
+ paymentForm.action = prepayUrl;
+ paymentForm.style.display = "none";
+ document.body.appendChild(paymentForm);
+ paymentForm.submit();
+ } else {
+ const payload = data.value.data.prepay_data;
+ WeixinJSBridge.invoke(
+ "getBrandWCPayRequest",
+ payload,
+ function (res) {
+ if (res.err_msg == "get_brand_wcpay_request:ok") {
+ // 支付成功,直接跳转到结果页面
+ router.push({
+ path: "/payment/result",
+ query: { orderNo: orderNoFromResp },
+ });
+ }
+ }
+ );
+ }
}
show.value = false;
- router.push({
- path: "/payment/result",
- query: { orderNo: orderNoFromResp },
- });
+ })
+ .catch(() => {
return;
- }
-
- if (selectedPaymentMethod.value === "alipay") {
- orderNo.value = orderNoFromResp;
- // 存储订单ID以便支付宝返回时获取
- const prepayUrl = prepayId;
- const paymentForm = document.createElement("form");
- paymentForm.method = "POST";
- paymentForm.action = prepayUrl;
- paymentForm.style.display = "none";
- document.body.appendChild(paymentForm);
- paymentForm.submit();
- } else {
- const payload = data.value.data.prepay_data;
- WeixinJSBridge.invoke(
- "getBrandWCPayRequest",
- payload,
- function (res) {
- if (res.err_msg == "get_brand_wcpay_request:ok") {
- // 支付成功,直接跳转到结果页面
- router.push({
- path: "/payment/result",
- query: { orderNo: orderNoFromResp },
- });
- }
- }
- );
- }
- }
- show.value = false;
+ });
}
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") {