test : 测试cas登录

This commit is contained in:
2024-03-05 20:48:52 +08:00
parent 8a7594b675
commit 768b467e6d
4 changed files with 83 additions and 43 deletions

View File

@@ -1,11 +1,12 @@
import { createRouter, createWebHistory } from 'vue-router' import {createRouter, createWebHistory} from 'vue-router'
import NProgress from 'nprogress' import NProgress from 'nprogress'
import 'nprogress/nprogress.css' import 'nprogress/nprogress.css'
import Layout from '@/layout/index.vue' import Layout from '@/layout/index.vue'
import { getToken } from '../utils/auth' import {getToken} from '../utils/auth'
import { usePermisstionStroe } from '@/stores/permisstion.js' import {usePermisstionStroe} from '@/stores/permisstion.js'
import { useAuthStore } from '@/stores/userstore.js' import {useAuthStore} from '@/stores/userstore.js'
NProgress.configure({ showSpinner: false })
NProgress.configure({showSpinner: false})
const router = createRouter({ const router = createRouter({
history: createWebHistory(import.meta.env.BASE_URL), history: createWebHistory(import.meta.env.BASE_URL),
@@ -13,12 +14,17 @@ const router = createRouter({
{ {
path: '/login', path: '/login',
name: 'login', name: 'login',
component: ()=>import('@/views/login/index.vue'), component: () => import('@/views/login/index.vue'),
meta: { meta: {
hidden: true, hidden: true,
title: '登录' title: '登录'
} }
}, },
{
path: '/cas/login',
name: 'casLogin',
component: () => import('@/views/cas-login/index.vue'),
},
{ {
path: '/', path: '/',
name: 'layout', name: 'layout',
@@ -31,7 +37,7 @@ const router = createRouter({
{ {
path: '/home', path: '/home',
name: 'home', name: 'home',
component: ()=>import('@/views/home/index.vue'), component: () => import('@/views/home/index.vue'),
meta: { meta: {
title: '首页', title: '首页',
breadcrumb: true breadcrumb: true
@@ -40,7 +46,7 @@ const router = createRouter({
{ {
path: '/auth', path: '/auth',
name: 'auth', name: 'auth',
component: ()=>import('@/views/auth/index.vue'), component: () => import('@/views/auth/index.vue'),
meta: { meta: {
title: '个人中心', title: '个人中心',
breadcrumb: true breadcrumb: true
@@ -49,7 +55,7 @@ const router = createRouter({
{ {
path: '/rapid/gen/edit/:tableId(\\d+)', path: '/rapid/gen/edit/:tableId(\\d+)',
name: 'genEdit', name: 'genEdit',
component: ()=>import('@/views/rapid/gen/editTable.vue'), component: () => import('@/views/rapid/gen/editTable.vue'),
meta: { meta: {
title: '数据库生成配置', title: '数据库生成配置',
breadcrumb: true breadcrumb: true
@@ -58,7 +64,7 @@ const router = createRouter({
{ {
path: '/workflow/process/edit/:deploymentId', path: '/workflow/process/edit/:deploymentId',
name: 'processEdit', name: 'processEdit',
component: ()=>import('@/views/workflow/process/ProcessEdit.vue'), component: () => import('@/views/workflow/process/ProcessEdit.vue'),
meta: { meta: {
title: '编辑流程', title: '编辑流程',
breadcrumb: true breadcrumb: true
@@ -69,14 +75,14 @@ const router = createRouter({
name: 'processAdd', name: 'processAdd',
component: () => import('@/views/workflow/process/ProcessEdit.vue'), component: () => import('@/views/workflow/process/ProcessEdit.vue'),
meta: { meta: {
title: '新增流程', title: '新增流程',
breadcrumb: true breadcrumb: true
} }
}, },
{ {
path: '/role-auth/user/:roleId(\\d+)/:roleName', path: '/role-auth/user/:roleId(\\d+)/:roleName',
name: 'distribute', name: 'distribute',
component: ()=>import('@/views/system/role/DistributeUser.vue'), component: () => import('@/views/system/role/DistributeUser.vue'),
meta: { meta: {
title: '角色分配用户', title: '角色分配用户',
breadcrumb: true breadcrumb: true
@@ -85,7 +91,7 @@ const router = createRouter({
{ {
path: '/post-auth/user/:postId(\\d+)/:postName', path: '/post-auth/user/:postId(\\d+)/:postName',
name: 'assignUser', name: 'assignUser',
component: ()=>import('@/views/system/post/DistributeUser.vue'), component: () => import('@/views/system/post/DistributeUser.vue'),
meta: { meta: {
title: '岗位分配用户', title: '岗位分配用户',
breadcrumb: true breadcrumb: true
@@ -94,7 +100,7 @@ const router = createRouter({
{ {
path: '/menu-auth/role/:menuId(\\d+)/:menuName', path: '/menu-auth/role/:menuId(\\d+)/:menuName',
name: 'assignRole', name: 'assignRole',
component: ()=>import('@/views/system/menu/DistributeRole.vue'), component: () => import('@/views/system/menu/DistributeRole.vue'),
meta: { meta: {
title: '菜单分配角色', title: '菜单分配角色',
breadcrumb: true breadcrumb: true
@@ -103,7 +109,7 @@ const router = createRouter({
{ {
path: '/system/notice/inform/index/:queryId', path: '/system/notice/inform/index/:queryId',
name: 'notify', name: 'notify',
component: ()=>import('@/views/system/notice/inform/index.vue'), component: () => import('@/views/system/notice/inform/index.vue'),
meta: { meta: {
title: '通知公告', title: '通知公告',
breadcrumb: false breadcrumb: false
@@ -112,7 +118,7 @@ const router = createRouter({
{ {
path: '/custom/query/sql/design/:queryId', path: '/custom/query/sql/design/:queryId',
name: 'sql', name: 'sql',
component: ()=>import('@/views/custom-query/sql/SqlDesign.vue'), component: () => import('@/views/custom-query/sql/SqlDesign.vue'),
meta: { meta: {
title: '自定义sql查询配置', title: '自定义sql查询配置',
breadcrumb: true breadcrumb: true
@@ -121,7 +127,7 @@ const router = createRouter({
{ {
path: '/custom/query/data/adapter/design/:queryId', path: '/custom/query/data/adapter/design/:queryId',
name: 'dataAdapter', name: 'dataAdapter',
component: ()=>import('@/views/custom-query/data-adapter/DataAdapterDesign.vue'), component: () => import('@/views/custom-query/data-adapter/DataAdapterDesign.vue'),
meta: { meta: {
title: '自定义数据适配器', title: '自定义数据适配器',
breadcrumb: true breadcrumb: true
@@ -130,7 +136,7 @@ const router = createRouter({
{ {
path: '/custom/query/echarts/design/:queryId', path: '/custom/query/echarts/design/:queryId',
name: 'echarts', name: 'echarts',
component: ()=>import('@/views/custom-query/echarts-editor/EchartsDesign.vue'), component: () => import('@/views/custom-query/echarts-editor/EchartsDesign.vue'),
meta: { meta: {
title: '自定义echarts查询配置', title: '自定义echarts查询配置',
breadcrumb: true breadcrumb: true
@@ -139,7 +145,7 @@ const router = createRouter({
{ {
path: '/rapid/data/:dsId(\\d+)', path: '/rapid/data/:dsId(\\d+)',
name: 'rapid', name: 'rapid',
component: ()=>import('@/views/rapid/gen/index.vue'), component: () => import('@/views/rapid/gen/index.vue'),
meta: { meta: {
title: '数据源关联数据', title: '数据源关联数据',
breadcrumb: true breadcrumb: true
@@ -150,7 +156,7 @@ const router = createRouter({
{ {
path: '/topo/design/:queryId', path: '/topo/design/:queryId',
name: 'topEdit', name: 'topEdit',
component: ()=>import('@/views/custom-query/topo/topologyDesign.vue'), component: () => import('@/views/custom-query/topo/topologyDesign.vue'),
meta: { meta: {
title: 'top', title: 'top',
breadcrumb: false breadcrumb: false
@@ -159,29 +165,29 @@ const router = createRouter({
{ {
path: '/forbidden', path: '/forbidden',
name: 'forbidden', name: 'forbidden',
component: ()=>import('@/views/forbidden/index.vue'), component: () => import('@/views/forbidden/index.vue'),
} }
] ]
}) })
router.beforeEach(async (to,form,next)=>{ router.beforeEach(async (to, form, next) => {
const permisstionStore = usePermisstionStroe() const permisstionStore = usePermisstionStroe()
const authStore = useAuthStore() const authStore = useAuthStore()
NProgress.start() NProgress.start()
if(!getToken()) { if (!getToken()) {
if(to.path === '/login' || to.path === '/forbidden') { if (to.path === '/login' || to.path === '/cas/login' || to.path === '/forbidden') {
next() next()
NProgress.done() NProgress.done()
}else { } else {
next({path: '/login'}) next({path: '/login'})
} }
}else { } else {
if(to.path === '/login') { if (to.path === '/login'|| to.path === '/cas/login') {
next('/') next('/')
NProgress.done() NProgress.done()
}else { } else {
permisstionStore.setIsLoadRoutes(true) permisstionStore.setIsLoadRoutes(true)
if(permisstionStore.isLoadRoutes && permisstionStore.asyncRouters.length==0){ if (permisstionStore.isLoadRoutes && permisstionStore.asyncRouters.length == 0) {
await permisstionStore.setAsyncRouters() await permisstionStore.setAsyncRouters()
await authStore.setUserInfo() await authStore.setUserInfo()
next({...to, replace: true}) next({...to, replace: true})
@@ -195,7 +201,7 @@ router.beforeEach(async (to,form,next)=>{
}) })
router.afterEach(()=>{ router.afterEach(() => {
NProgress.done() NProgress.done()
}) })

View File

@@ -1,20 +1,31 @@
import { defineStore } from "pinia"; import {defineStore} from "pinia";
import { ref } from "vue"; import {ref} from "vue";
import { getUserInfo, login } from "../api/login"; import {getUserInfo, login} from "../api/login";
import { ElMessage } from "element-plus"; import {ElMessage} from "element-plus";
import { removeToken, setToken} from "../utils/auth"; import {getToken, removeToken, setToken} from "../utils/auth";
export const useAuthStore = defineStore('auth',()=>{ export const useAuthStore = defineStore('auth', () => {
const userinfo = ref({}) const userinfo = ref({})
const permisstions = ref([]) const permisstions = ref([])
const roles = ref([]) const roles = ref([])
const casToken = (token) => {
console.log('getToken()!==token',getToken()!==token)
let flag=''
if(getToken()!==token){//切换token
setToken(token)
flag=true
}else {
flag=false
}
return flag;
}
const userLogin = async (data) => { const userLogin = async (data) => {
let flag let flag
await login(data).then(res=>{ await login(data).then(res => {
if(res?.code === 1000) { if (res?.code === 1000) {
setToken(res.data) setToken(res.data)
flag = true flag = true
}else { } else {
ElMessage.error(res.msg) ElMessage.error(res.msg)
flag = false flag = false
} }
@@ -25,7 +36,7 @@ export const useAuthStore = defineStore('auth',()=>{
removeToken() removeToken()
} }
const setUserInfo = async () => { const setUserInfo = async () => {
await getUserInfo().then(res=>{ await getUserInfo().then(res => {
userinfo.value = res.data.user userinfo.value = res.data.user
permisstions.value = res.data.permissions permisstions.value = res.data.permissions
roles.value = res.data.roles roles.value = res.data.roles
@@ -35,6 +46,7 @@ export const useAuthStore = defineStore('auth',()=>{
return { return {
userinfo, userinfo,
permisstions, permisstions,
casToken,
userLogin, userLogin,
userLogout, userLogout,
setUserInfo setUserInfo

View File

@@ -0,0 +1,22 @@
<script setup>
import {useRouter} from 'vue-router';
import {useAuthStore} from '@/stores/userstore'
import {ElLoading} from 'element-plus'
const authStore = useAuthStore()
const router = useRouter();
const tokenValue = reactive(router.currentRoute.value.query.token)
console.log('tokenValue', tokenValue)
const init = () => {
// console.log('authStore.casToken(tokenValue)',authStore.casToken(tokenValue))
if (authStore.casToken(tokenValue)) {
// ElLoading.service({text: '正在加载系统资源', background: '#409eff', lock: true})
router.push('/')
}
// else {
// router.push('/login')
// }
}
init()
</script>

View File

@@ -69,11 +69,11 @@ export default defineConfig({
open: true, open: true,
proxy: { proxy: {
'/api': { '/api': {
target: 'http://fateverse-vue.frp.feashow.cn', target: 'http://mosr.feashow.cn',
changeOrigin: true, changeOrigin: true,
}, },
'/api/notice-ws': { '/api/notice-ws': {
target: 'ws://fateverse-vue.frp.feashow.cn/api/notice-ws', target: 'ws://mosr.feashow.cn/api/notice-ws',
ws: true, ws: true,
changeOrigin: true, changeOrigin: true,
} }