Commit 88191408 authored by liuzhaoh's avatar liuzhaoh

增加登录逻辑

parent b45a5d92
...@@ -13,6 +13,7 @@ ...@@ -13,6 +13,7 @@
"crypto-js": "^4.2.0", "crypto-js": "^4.2.0",
"element-plus": "^2.9.10", "element-plus": "^2.9.10",
"js-cookie": "^3.0.5", "js-cookie": "^3.0.5",
"nprogress": "^0.2.0",
"path": "^0.12.7", "path": "^0.12.7",
"pinia": "^3.0.2", "pinia": "^3.0.2",
"qs": "^6.14.0", "qs": "^6.14.0",
......
...@@ -9,16 +9,17 @@ ...@@ -9,16 +9,17 @@
<el-dropdown trigger="click"> <el-dropdown trigger="click">
<div class="user-info"> <div class="user-info">
<img <svg color="red" data-icon-name="user-circle" data-style="line" icon_origin_id="24289" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg" id="user-circle" class="icon line" width="40" height="40"><path style="fill: none; stroke: rgb(1, 135, 150); stroke-linecap: round; stroke-linejoin: round; stroke-width: 1;" d="M12,21h0a9,9,0,0,1-9-9H3a9,9,0,0,1,9-9h0a9,9,0,0,1,9,9h0A9,9,0,0,1,12,21Zm0-6a5,5,0,0,0-5,4.5,9,9,0,0,0,9.94,0A5,5,0,0,0,12,15Zm0-8a4,4,0,1,0,4,4A4,4,0,0,0,12,7Z" id="primary"></path></svg>
<!-- <img
src="" src=""
class="user-avatar" class="user-avatar"
/> /> -->
<span class="user-name">用户1</span> <span class="user-name">{{ userName }}</span>
</div> </div>
<template #dropdown> <template #dropdown>
<el-dropdown-menu> <el-dropdown-menu>
<el-dropdown-item :icon="Plus">退出登录</el-dropdown-item> <el-dropdown-item :icon="Plus" @click="logout">退出登录</el-dropdown-item>
</el-dropdown-menu> </el-dropdown-menu>
</template> </template>
</el-dropdown> </el-dropdown>
...@@ -41,12 +42,15 @@ import menuCom from "./menuCom.vue"; ...@@ -41,12 +42,15 @@ import menuCom from "./menuCom.vue";
import { CaretBottom, Plus } from "@element-plus/icons-vue"; import { CaretBottom, Plus } from "@element-plus/icons-vue";
import { useRoute, useRouter } from 'vue-router'; import { useRoute, useRouter } from 'vue-router';
import { watch, ref, onMounted } from 'vue'; import { watch, ref, onMounted } from 'vue';
import { getToken } from '@/utils/auth';
import { useUsersStore } from "@/pinia/user.js";
export default { export default {
components: { components: {
menuCom, menuCom,
}, },
setup() { setup() {
const router = useRouter();
const route = useRoute(); const route = useRoute();
const breadcrumbList = ref([]); const breadcrumbList = ref([]);
...@@ -81,8 +85,20 @@ export default { ...@@ -81,8 +85,20 @@ export default {
getBreadcrumbData(); getBreadcrumbData();
}); });
const userName = getToken('userName')
const store = useUsersStore();
async function logout() {
sessionStorage.setItem("permissionData", "");
sessionStorage.setItem("branchFactoryList", []);
sessionStorage.setItem("primaryTypeList", []);
await store.logout();
store.istrue = false;
router.push({ path: '/login' });
}
return { return {
breadcrumbList breadcrumbList,
userName,
logout
}; };
}, },
created() { created() {
......
...@@ -2,12 +2,15 @@ import { createApp } from 'vue' ...@@ -2,12 +2,15 @@ import { createApp } from 'vue'
import './style.css' import './style.css'
import App from './App.vue' import App from './App.vue'
import { router } from './router' import { router } from './router'
import '@/router/routePermission.js'
import ElementPlus from 'element-plus' import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css' import 'element-plus/dist/index.css'
import * as ElementPlusIconsVue from '@element-plus/icons-vue' import * as ElementPlusIconsVue from '@element-plus/icons-vue'
import { createPinia } from 'pinia' import { createPinia } from 'pinia'
const app = createApp(App) const app = createApp(App)
for (const [key, component] of Object.entries(ElementPlusIconsVue)) { for (const [key, component] of Object.entries(ElementPlusIconsVue)) {
app.component(key, component) app.component(key, component)
......
...@@ -76,6 +76,56 @@ export const useUsersStore = defineStore('user', { ...@@ -76,6 +76,56 @@ export const useUsersStore = defineStore('user', {
}) })
}) })
}, },
logout() {
return new Promise((resolve, reject) => {
logout().then((res) => {
if (res.code == 1) {
this.token = ''
this.roles = []
removeToken('TOKEN');
removeToken('appCode');
// resetRouter()
}
resolve()
}).catch(error => {
reject(error)
})
})
},
getInfo(userInfo) {
return new Promise((resolve, reject) => {
getInfo().then(response => {
if (response.code != 1) {
return reject('验证失败,请重新登录!')
}
const { data } = response
findPcMenu(this.customerId).then(res => {
let menuLimits = res.data
let menuLimitsObj = {}
if (res.code == 1) {
if (menuLimits.length > 0) {
for (let item of menuLimits) {
menuLimitsObj[item.configName] = item.configName
}
}
this.menuLimitsObj = menuLimitsObj
this.roles = data
resolve(data)
}
})
}).catch(error => {
reject(error)
})
})
},
resetToken() {
return new Promise(resolve => {
this.token = ''
this.roles = []
removeToken()
resolve()
})
},
}, },
}) })
import { router } from './index.js'
import { getToken } from '@/utils/auth'
import { useUsersStore } from "@/pinia/user.js";
import NProgress from 'nprogress'
import 'nprogress/nprogress.css' // progress bar style
NProgress.configure({ showSpinner: false }) // NProgress Configuration
const whiteList = ['/login', '/auth-redirect'] // no redirect whitelist
router.beforeEach(async (to, from, next) => {
const store = useUsersStore()
const hasToken = getToken('TOKEN')
// start progress bar
NProgress.start()
if (hasToken) {
if (to.path.includes('/login')) {
if (to.path == '/login') {
next()
} else {
next('/login')
}
NProgress.done()
} else {
const hasRoles = store.roles && store.roles.length > 0
if (hasRoles) {
if (from.path.includes('/login') || to.path.includes('/dashboard')) {
next()
} else {
// 攀长特安全问题修复 未授权路由禁止跳转
if (store.customerId == 138) {
let hasPermission = false
store.roles.forEach((i) => {
let arr = to.path.split('/')
if (arr[arr.length - 1] === i.url) {
hasPermission = true
}
})
if (hasPermission) {
next()
} else {
Message.warning({
type: 'warning',
message: '没有访问权限,如果需要访问请联系管理员',
duration: 2000
});
router.go(-1)
}
} else {
next()
}
}
} else {
try {
// debugger
// get user info
// note: roles must be a object array! such as: ['admin'] or ,['developer','editor']
const roles = await store.getInfo()
// generate accessible routes map based on roles
const menuLimitsObj = await store.menuLimitsObj
// const accessRoutes = await store.dispatch('permission/generateRoutes', { roles, menuLimitsObj })
// console.log("accessRoutes",accessRoutes)
// dynamically add accessible routes
// router.addRoutes(accessRoutes)
// hack method to ensure that addRoutes is complete
// set the replace: true, so the navigation will not leave a history record
// next({ ...to, replace: true })
next()
} catch (error) {
console.log(error)
// remove token and go to login page to re-login
await store.resetToken()
// Message.warning(error || 'Has Error')
next(`/login?redirect=${to.path}`)
}
}
}
} else {
if (whiteList.indexOf(to.path) !== -1) {
// in the free login whitelist, go directly
next()
} else {
// other pages that do not have permission to access are redirected to the login page.
// next(`/login?redirect=${to.path}`)
next(`/login`)
NProgress.done()
}
}
})
router.afterEach(() => {
// finish progress bar
NProgress.done()
})
\ No newline at end of file
import { enc } from "crypto-js";
// corypto-js的base6-utf8加密
export function encryptBase64ToUtf8(msg) {
return enc.Base64.stringify(enc.Utf8.parse(msg))
}
// corypto-js的base6-utf8解密
export function encryptUtf8ToBase64(encoded_msg) {
return enc.Utf8.stringify(enc.Base64.parse(encoded_msg)).toString()
}
\ No newline at end of file
...@@ -258,6 +258,7 @@ import { getToken, removeToken, setToken } from "@/utils/auth"; ...@@ -258,6 +258,7 @@ import { getToken, removeToken, setToken } from "@/utils/auth";
import { getData, getDataFun, postData } from "@/request/method"; import { getData, getDataFun, postData } from "@/request/method";
import { ElMessage } from "element-plus"; import { ElMessage } from "element-plus";
import { MD5 } from "crypto-js"; import { MD5 } from "crypto-js";
import { encryptUtf8ToBase64, encryptBase64ToUtf8 } from "@/utils/tools.js";
export default { export default {
name: "Login", name: "Login",
data() { data() {
...@@ -485,7 +486,7 @@ export default { ...@@ -485,7 +486,7 @@ export default {
password: "", password: "",
captcha: "", captcha: "",
captchaKey: "", captchaKey: "",
rememberMe: false, rememberMe: getToken("rememberMe") == 'true' ? true : false,
}, },
dialogPhoneBind: false, dialogPhoneBind: false,
store: null, store: null,
...@@ -522,7 +523,7 @@ export default { ...@@ -522,7 +523,7 @@ export default {
account: "", account: "",
password: "", password: "",
captcha: "", captcha: "",
rememberMe: false, rememberMe: getToken("rememberMe") == 'true' ? true : false,
}; };
}, },
mounted() { mounted() {
...@@ -533,6 +534,14 @@ export default { ...@@ -533,6 +534,14 @@ export default {
this.loginForm.account = ""; this.loginForm.account = "";
this.loginForm.password = ""; this.loginForm.password = "";
} }
if (getToken("rememberMe") == "true") {
this.loginOldForm.account = encryptUtf8ToBase64(getToken("account"));
this.loginOldForm.password = encryptUtf8ToBase64(getToken("remmberPWS"));
console.log(this.loginOldForm)
} else {
this.loginOldForm.account = "";
this.loginOldForm.password = "";
}
this.debounceAction = this.debounce(this.handleAccountInput, 100); this.debounceAction = this.debounce(this.handleAccountInput, 100);
}, },
destroyed() { destroyed() {
...@@ -795,7 +804,6 @@ export default { ...@@ -795,7 +804,6 @@ export default {
"&appCode=bme-pc-service", "&appCode=bme-pc-service",
true true
).then((result) => { ).then((result) => {
console.log(result.data);
if (result.code == 1 && result.data && result.data.length > 0) { if (result.code == 1 && result.data && result.data.length > 0) {
this.phoneForm.account = this.loginForm.account; this.phoneForm.account = this.loginForm.account;
this.phoneForm.password = this.loginForm.password; this.phoneForm.password = this.loginForm.password;
...@@ -840,7 +848,6 @@ export default { ...@@ -840,7 +848,6 @@ export default {
account: this.phoneForm.account, account: this.phoneForm.account,
iphone: this.phoneForm.iphone, iphone: this.phoneForm.iphone,
}).then((res) => { }).then((res) => {
console.log(res.data);
if (res.code == 1) { if (res.code == 1) {
this.getProfile(data); this.getProfile(data);
} }
...@@ -877,6 +884,7 @@ export default { ...@@ -877,6 +884,7 @@ export default {
setToken("dataBranchFactoryId", data.data.dataBranchFactoryId); setToken("dataBranchFactoryId", data.data.dataBranchFactoryId);
setToken("customerId", customerId); setToken("customerId", customerId);
setToken("userId", data.data.id); setToken("userId", data.data.id);
setToken("userName", data.data.name);
sessionStorage.setItem("userId", data.data.id); sessionStorage.setItem("userId", data.data.id);
let homeFlag = await this.getPermissionData(data.data.id); let homeFlag = await this.getPermissionData(data.data.id);
this.store.customerId = customerId; this.store.customerId = customerId;
...@@ -956,6 +964,9 @@ export default { ...@@ -956,6 +964,9 @@ export default {
handleOldLogin() { handleOldLogin() {
this.$refs.loginOldForm.validate((valid) => { this.$refs.loginOldForm.validate((valid) => {
if (valid) { if (valid) {
// 记住密码
setToken('account', encryptBase64ToUtf8(this.loginOldForm.account))
setToken('remmberPWS', encryptBase64ToUtf8(this.loginOldForm.password))
this.oldloading = true; this.oldloading = true;
this.loginOldForm.appCode = "bme-pc-service"; this.loginOldForm.appCode = "bme-pc-service";
const loginOldFormOrigin = { ...this.loginOldForm }; const loginOldFormOrigin = { ...this.loginOldForm };
...@@ -1001,6 +1012,7 @@ export default { ...@@ -1001,6 +1012,7 @@ export default {
setToken("dataBranchFactoryId", data.data.dataBranchFactoryId); setToken("dataBranchFactoryId", data.data.dataBranchFactoryId);
setToken("customerId", customerId); setToken("customerId", customerId);
setToken("userId", data.data.id); setToken("userId", data.data.id);
setToken("userName", data.data.name);
sessionStorage.setItem("userId", data.data.id); sessionStorage.setItem("userId", data.data.id);
let homeFlag = await this.getPermissionData(data.data.id); let homeFlag = await this.getPermissionData(data.data.id);
this.store.customerId = customerId; this.store.customerId = customerId;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment