test : 测试cas登录
This commit is contained in:
@@ -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()
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
22
src/views/cas-login/index.vue
Normal file
22
src/views/cas-login/index.vue
Normal 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>
|
||||||
|
|
||||||
@@ -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,
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user