dssff
This commit is contained in:
parent
20b415ffc4
commit
3bcd80be76
@ -1,19 +1,8 @@
|
|||||||
// 在登录成功后请调用 resetTokenInvalid() 重置 isTokenInvalid 标志
|
|
||||||
let isTokenInvalid = false;
|
|
||||||
|
|
||||||
const baseUrl = 'https://ddbs.1024tool.vip/';
|
const baseUrl = 'https://ddbs.1024tool.vip/';
|
||||||
let isNavigatingToLogin = false;
|
|
||||||
|
|
||||||
// 重置 token 失效标志(登录成功后调用)
|
|
||||||
export function resetTokenInvalid() {
|
|
||||||
isTokenInvalid = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
function request(url, method = 'GET', data = {}) {
|
function request(url, method = 'GET', data = {}) {
|
||||||
// 如果 token 已失效,直接中断请求
|
|
||||||
if (isTokenInvalid) {
|
|
||||||
return Promise.reject({ code: 10103, message: '登录已失效,请重新登录' });
|
|
||||||
}
|
|
||||||
const header = {
|
const header = {
|
||||||
'content-type': 'application/json',
|
'content-type': 'application/json',
|
||||||
// 有其他content-type需求加点逻辑判断处理即可
|
// 有其他content-type需求加点逻辑判断处理即可
|
||||||
@ -24,22 +13,16 @@ function request(url, method = 'GET', data = {}) {
|
|||||||
header.Authorization = `${tokenString}`;
|
header.Authorization = `${tokenString}`;
|
||||||
}
|
}
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
wx.request({
|
wx.request({
|
||||||
url: baseUrl + url,
|
url: baseUrl + url,
|
||||||
method,
|
method,
|
||||||
data,
|
data,
|
||||||
dataType: 'json', // 微信官方文档中介绍会对数据进行一次JSON.parse
|
dataType: 'json', // 微信官方文档中介绍会对数据进行一次JSON.parse
|
||||||
header,
|
header,
|
||||||
success(res) {
|
success(res) {
|
||||||
if (res.data.code) {
|
if (res.data.code) {
|
||||||
if (res.data.code == 10103) {
|
if (res.data.code == 10103) {
|
||||||
isTokenInvalid = true;
|
wx.removeStorageSync('access_token');
|
||||||
wx.removeStorageSync('access_token');
|
|
||||||
if (!isNavigatingToLogin) {
|
|
||||||
const pages = getCurrentPages();
|
|
||||||
const currentRoute = pages[pages.length - 1]?.route;
|
|
||||||
if (currentRoute !== 'pages/login/login') {
|
|
||||||
isNavigatingToLogin = true;
|
|
||||||
wx.navigateTo({
|
wx.navigateTo({
|
||||||
url: '/pages/login/login',
|
url: '/pages/login/login',
|
||||||
complete: () => {
|
complete: () => {
|
||||||
@ -47,26 +30,25 @@ function request(url, method = 'GET', data = {}) {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
reject(res.data);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
wx.showToast({
|
||||||
|
title: res.data.message,
|
||||||
|
icon: 'none'
|
||||||
|
});
|
||||||
reject(res.data);
|
reject(res.data);
|
||||||
return;
|
} else {
|
||||||
|
resolve(res.data);
|
||||||
}
|
}
|
||||||
wx.showToast({
|
|
||||||
title: res.data.message,
|
|
||||||
icon: 'none'
|
|
||||||
});
|
|
||||||
reject(res.data);
|
|
||||||
} else {
|
|
||||||
resolve(res.data);
|
|
||||||
}
|
|
||||||
|
|
||||||
},
|
},
|
||||||
fail(err) {
|
fail(err) {
|
||||||
console.log(err)
|
console.log(err)
|
||||||
// 断网、服务器挂了都会fail回调,直接reject即可
|
// 断网、服务器挂了都会fail回调,直接reject即可
|
||||||
reject(err);
|
reject(err);
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -1,5 +1,4 @@
|
|||||||
import request from '~/api/request';
|
import request from '~/api/request';
|
||||||
import { resetTokenInvalid } from '~/api/request';
|
|
||||||
import { aesCryptoJS } from '~/utils/util';
|
import { aesCryptoJS } from '~/utils/util';
|
||||||
|
|
||||||
Page({
|
Page({
|
||||||
@ -47,7 +46,6 @@ Page({
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
resetTokenInvalid()
|
|
||||||
const res = await request('doctor/login', 'post', {
|
const res = await request('doctor/login', 'post', {
|
||||||
password: aesCryptoJS(this.data.password),
|
password: aesCryptoJS(this.data.password),
|
||||||
mobile: this.data.mobile
|
mobile: this.data.mobile
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user