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

@@ -5,6 +5,7 @@ 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({
@@ -19,6 +20,11 @@ const router = createRouter({
title: '登录' title: '登录'
} }
}, },
{
path: '/cas/login',
name: 'casLogin',
component: () => import('@/views/cas-login/index.vue'),
},
{ {
path: '/', path: '/',
name: 'layout', name: 'layout',
@@ -169,14 +175,14 @@ router.beforeEach(async (to,form,next)=>{
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 {

View File

@@ -2,12 +2,23 @@ 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 => {
@@ -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,
} }