Browse Source

优化token失效重新登录

master
gaoxs 5 years ago
parent
commit
8267cbc18e
  1. 4
      components/CouponWindow.vue
  2. 52
      libs/login.js
  3. 46
      pages/authorization/index.vue
  4. 3
      pages/user/User/index.vue
  5. 1
      store/index.js
  6. 51
      utils/index.js

4
components/CouponWindow.vue

@ -29,7 +29,7 @@
import { import {
mapGetters mapGetters
} from "vuex"; } from "vuex";
import toLogin from "@/libs/login"; import {handleLoginFailure} from "@/utils";
import { import {
couponReceiveBatch couponReceiveBatch
} from "@/api/user"; } from "@/api/user";
@ -52,7 +52,7 @@
methods: { methods: {
checked() { checked() {
const isLogin = this.isLogin; const isLogin = this.isLogin;
if (!isLogin) return toLogin(); if (!isLogin) return handleLoginFailure();
const ids = this.couponList.reduce((initial, coupon) => { const ids = this.couponList.reduce((initial, coupon) => {
initial.push(coupon.id); initial.push(coupon.id);

52
libs/login.js

@ -1,52 +0,0 @@
// import router from "../router";
import store from "../store";
import cookie from "@/utils/store/cookie";
import {
isWeixin,
login,
getCurrentPageUrl,
getCurrentPageUrlWithArgs,
parseQuery,
replace,
routerPermissions,
handleQrCode
} from "@/utils";
export default function toLogin(push, backUrl) {
console.log('token失效,需要重新登录')
store.commit("LOGOUT");
// 如果没有授权,走登录的接口重新授权
// 授权获取失败会跳转到授权的接口
console.log(store.getters.isAuthorization, '是否有登陆权限')
if (store.getters.isAuthorization) {
login()
return
}
console.log(store.getters.isAuthorizationPage, '判断是不是登录页面或者授权页面')
// 判断当前是不是已经在登录页面或者授权页,防止二次跳转
if (store.getters.isAuthorizationPage || getCurrentPageUrl() == '/pages/user/Login/index') {
console.log('已经是登录页面或者授权页面,跳出方法')
return
}
// 判断是不是扫描的砍价海报进来的
if (getCurrentPageUrl() == 'pages/activity/DargainDetails/index' && handleQrCode()) {
console.log('是扫描的砍价海报进来的')
let url = handleQrCode();
if (url) {
replaceLogin({
redirect: `/${getCurrentPageUrl()}`,
id: url.bargainId,
partake: url.uid
})
} else {
console.log('是扫描的砍价海报进来的,但是没有获取到参数')
routerPermissions()
}
} else {
console.log('无特殊情况,重新登录')
routerPermissions()
}
store.commit("UPDATE_AUTHORIZATION", false);
store.commit("UPDATE_AUTHORIZATIONPAGE", true);
}

46
pages/authorization/index.vue

@ -2,7 +2,7 @@
<view class="container"> <view class="container">
<view v-if="!token"> <view v-if="!token">
<!-- 小程序 --> <!-- 小程序 -->
<view v-if="$deviceType == 'routine'&&!authorize"> <view v-if="$deviceType == 'routine'&&authorize">
<view class="getUserInfo"> <view class="getUserInfo">
<text>您还未允许微信登录授权请点击下方按钮允许微信授权登录</text> <text>您还未允许微信登录授权请点击下方按钮允许微信授权登录</text>
<button type="primary" open-type="getUserInfo" @getuserinfo="getUserInfo">允许微信登录授权</button> <button type="primary" open-type="getUserInfo" @getuserinfo="getUserInfo">允许微信登录授权</button>
@ -11,12 +11,17 @@
</view> </view>
</view> </view>
<!-- app --> <!-- app -->
<view v-if="$deviceType == 'app'&&!authorize"> <view v-if="$deviceType == 'app'&&authorize">
<view class="getUserInfo"> <view class="getUserInfo">
<text>请先登录</text> <text>请先登录</text>
<button type="primary" @click="this.toLogin">去登录</button> <button type="primary" @click="this.toLogin">去登录</button>
</view> </view>
</view> </view>
<view v-if="!authorize">
<view class="getUserInfo">
<text>登录中</text>
</view>
</view>
</view> </view>
</view> </view>
</template> </template>
@ -33,7 +38,7 @@ import { login, authorize } from "@/utils";
export default { export default {
data() { data() {
return { return {
authorize: true authorize: false
}; };
}, },
computed: { computed: {
@ -41,19 +46,25 @@ export default {
}, },
onShow() { onShow() {
this.UPDATE_AUTHORIZATIONPAGE(true); this.UPDATE_AUTHORIZATIONPAGE(true);
// // //
console.log("先校验用户是否授权,如果没有授权,显示授权按钮");
authorize("userInfo") authorize("userInfo")
.then(() => {}) .then(res => {
console.log(res);
})
.catch(error => { .catch(error => {
console.log(error);
// //
this.authorize = true; this.authorize = true;
}); });
}, },
onHide() { onHide() {
console.log("离开授权页面,11111");
this.UPDATE_AUTHORIZATIONPAGE(false); this.UPDATE_AUTHORIZATIONPAGE(false);
this.changeAuthorization(false); this.changeAuthorization(false);
}, },
onUnload() { onUnload() {
console.log("离开授权页面,11111");
this.UPDATE_AUTHORIZATIONPAGE(false); this.UPDATE_AUTHORIZATIONPAGE(false);
this.changeAuthorization(false); this.changeAuthorization(false);
}, },
@ -85,7 +96,7 @@ export default {
.catch(error => { .catch(error => {
console.log(error); console.log(error);
uni.showToast({ uni.showToast({
title: "登录失败", title: error,
icon: "none", icon: "none",
duration: 2000 duration: 2000
}); });
@ -98,8 +109,27 @@ export default {
}); });
} }
}, },
onUnload() {}, onUnload() {
mounted() {} console.log("离开授权页面,11111");
this.UPDATE_AUTHORIZATIONPAGE(false);
this.changeAuthorization(false);
},
mounted() {
// console.log(",11111");
// this.UPDATE_AUTHORIZATIONPAGE(true);
// //
// console.log("");
// authorize("userInfo")
// .then(res => {
// console.log(res);
// this.authorize = false;
// })
// .catch(error => {
// console.log(error);
// //
// this.authorize = true;
// });
}
}; };
</script> </script>

3
pages/user/User/index.vue

@ -297,6 +297,7 @@ export default {
that.MyMenus = res.data.routine_my_menus; that.MyMenus = res.data.routine_my_menus;
}) })
.catch(error => { .catch(error => {
uni.hideLoading();
console.log(error); console.log(error);
}); });
}, },
@ -342,7 +343,7 @@ export default {
if (this.$store.getters.token) { if (this.$store.getters.token) {
// //
uni.showLoading({ uni.showLoading({
title: "绑定中" title: "加载中"
}); });
this.$store.dispatch("getUser", true); this.$store.dispatch("getUser", true);
this.MenuUser(); this.MenuUser();

1
store/index.js

@ -51,6 +51,7 @@ const vuexStore = new Vuex.Store({
cookie.set(LOGIN_KEY, token, expires_time); cookie.set(LOGIN_KEY, token, expires_time);
}, },
LOGOUT(state) { LOGOUT(state) {
console.log('清除数据')
state.token = null; state.token = null;
state.userInfo = null state.userInfo = null
let spread = cookie.get('spread') let spread = cookie.get('spread')

51
utils/index.js

@ -132,22 +132,21 @@ export const getProvider = (service) => {
export const authorize = (authorizeStr) => { export const authorize = (authorizeStr) => {
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
console.log('检验授权') console.log('检验授权', `scope.${authorizeStr}`)
uni.authorize({ uni.getSetting({
scope: `scope.${authorizeStr}`, success(res) {
success() { console.log(res.authSetting)
console.log('检验授权____授权成功') if (res.authSetting[`scope.${authorizeStr}`]) {
resolve('获取授权成功') resolve('获取授权成功')
} else {
reject('获取授权失败')
}
}, },
fail() { fail() {
console.log('检验授权____授权失败') reject('获取设置失败')
// switchTab({
// path: '/pages/home/index',
// // query
// });
reject('获取授权失败')
} }
}) })
}) })
} }
@ -383,6 +382,13 @@ export const handleLoginStatus = (location, complete, fail, success) => {
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
if (isAuth) { if (isAuth) {
// 有token // 有token
if (path == '/pages/home/index' || path == '/pages/shop/GoodsClass/index' || path == '/pages/shop/ShoppingCart/index' || path == '/pages/user/User/index') {
// switchTab({
// path: parseUrl(location),
// })
// return
}
resolve({ resolve({
url: parseUrl(location), url: parseUrl(location),
complete, complete,
@ -404,6 +410,7 @@ export const handleLoginStatus = (location, complete, fail, success) => {
// } // }
export function routerPermissions(url, type) { export function routerPermissions(url, type) {
console.log('routerPermissions', url)
let path = url let path = url
if (!path) { if (!path) {
path = getCurrentPageUrlWithArgs() path = getCurrentPageUrlWithArgs()
@ -416,6 +423,11 @@ export function routerPermissions(url, type) {
// 自动登录 // 自动登录
login().then(res => { login().then(res => {
// 登录成功,跳转到需要跳转的页面 // 登录成功,跳转到需要跳转的页面
console.log('登录成功,跳转页面')
store.commit("UPDATE_AUTHORIZATIONPAGE", false);
if (path == '/pages/shop/ShoppingCart/index' || path == '/pages/user/User/index') {
return
}
if (type == 'reLaunch') { if (type == 'reLaunch') {
reLaunch({ reLaunch({
path, path,
@ -438,6 +450,13 @@ export function routerPermissions(url, type) {
}) })
}).catch(error => { }).catch(error => {
// 跳转到登录页面或者授权页面 // 跳转到登录页面或者授权页面
if (path == '/pages/shop/ShoppingCart/index' || path == '/pages/user/User/index') {
switchTab({
path,
})
store.commit("UPDATE_AUTHORIZATIONPAGE", false);
return
}
reLaunch({ reLaunch({
path: '/pages/authorization/index', path: '/pages/authorization/index',
}) })
@ -664,6 +683,8 @@ export const PosterCanvas = (store, successCallBack) => {
export const handleLoginFailure = () => { export const handleLoginFailure = () => {
store.commit("LOGOUT");
store.commit("UPDATE_AUTHORIZATION", false);
// token 失效 // token 失效
// 判断当前是不是已经在登录页面或者授权页,防止二次跳转 // 判断当前是不是已经在登录页面或者授权页,防止二次跳转
@ -672,8 +693,8 @@ export const handleLoginFailure = () => {
return return
} }
store.commit("LOGOUT"); console.log('当前是授权页面')
store.commit("UPDATE_AUTHORIZATION", false); console.log(store.getters)
store.commit("UPDATE_AUTHORIZATIONPAGE", true); store.commit("UPDATE_AUTHORIZATIONPAGE", true);
let path = getCurrentPageUrlWithArgs() let path = getCurrentPageUrlWithArgs()
@ -735,6 +756,8 @@ export const handleLoginFailure = () => {
} }
} }
routerPermissions(path, 'reLaunch') routerPermissions(path, 'reLaunch')
} }

Loading…
Cancel
Save