!23 统一登录,授权

Merge pull request !23 from 三个三/auth
This commit is contained in:
疯狂的狮子Li 2023-07-02 07:40:13 +00:00 committed by Gitee
commit 4cf836055a
No known key found for this signature in database
GPG Key ID: 173E9B9CA92EEF8F
5 changed files with 96 additions and 40 deletions

View File

@ -2,6 +2,7 @@ import request from '@/utils/request';
import { AxiosPromise } from 'axios'; import { AxiosPromise } from 'axios';
import { LoginData, LoginResult, VerifyCodeResult, TenantInfo } from './types'; import { LoginData, LoginResult, VerifyCodeResult, TenantInfo } from './types';
import { UserInfo } from '@/api/system/user/types'; import { UserInfo } from '@/api/system/user/types';
import { da } from 'element-plus/es/locale';
/** /**
* @param data {LoginData} * @param data {LoginData}
@ -9,13 +10,9 @@ import { UserInfo } from '@/api/system/user/types';
*/ */
export function login(data: LoginData): AxiosPromise<LoginResult> { export function login(data: LoginData): AxiosPromise<LoginResult> {
const params = { const params = {
tenantId: data.tenantId, ...data,
username: data.username.trim(), clientId: data.clientId || 'e5cd7e4891bf95d1d19206ce24a7b32e',
password: data.password, grantType: data.grantType || 'password'
code: data.code,
uuid: data.uuid,
clientId: 'e5cd7e4891bf95d1d19206ce24a7b32e',
grantType: 'password'
}; };
return request({ return request({
url: '/auth/login', url: '/auth/login',
@ -66,16 +63,16 @@ export function getCodeImg(): AxiosPromise<VerifyCodeResult> {
* *
* @param source * @param source
* */ * */
export function socialLogin(source: string, code: any, state: any): AxiosPromise<any> { export function callback(data: LoginData): AxiosPromise<any> {
const data = { const LoginData = {
code, ...data,
state, clientId: 'e5cd7e4891bf95d1d19206ce24a7b32e',
source grantType: 'social'
}; };
return request({ return request({
url: '/auth/social-login', url: '/auth/social/callback',
method: 'get', method: 'post',
params: data data: LoginData
}); });
} }

View File

@ -15,10 +15,13 @@ export type RegisterForm = {
* *
*/ */
export interface LoginData { export interface LoginData {
tenantId: string; tenantId?: string;
username: string; username?: string;
password: string; password?: string;
rememberMe?: boolean; rememberMe?: boolean;
socialCode?: string,
socialState?: string,
source?: string,
code?: string; code?: string;
uuid?: string; uuid?: string;
clientId: string; clientId: string;

View File

@ -3,34 +3,80 @@
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
import {socialLogin} from '@/api/login'; import { login, callback } from '@/api/login';
import {setToken} from '@/utils/auth'; import { setToken } from '@/utils/auth';
import Cookies from 'js-cookie';
import { getToken } from '@/utils/auth';
import { LoginData } from '@/api/types';
const route = useRoute(); const route = useRoute();
const router = useRouter(); const loading = ref(true);
/** /**
* 接收Route传递的参数 * 接收Route传递的参数
* @param {Object} route.query. * @param {Object} route.query.
*/ */
const code = route.query.code; const code = route.query.code as string;
const state = route.query.state; const state = route.query.state as string;
const source = route.query.source as string; const source = route.query.source as string;
const loading = ref(true); const tenantId = Cookies.get("tenantId") ? Cookies.get("tenantId") as string : '000000';
await socialLogin(source, code, state)
.then(async (res) => {
if (res.code !== 200) { const processResponse = async (res: any) => {
ElMessage.error(res.msg); if (res.code !== 200) {
location.href = import.meta.env.VITE_APP_CONTEXT_PATH + 'index'; throw new Error(res.msg);
return; }
} setToken(res.data.access_token);
ElMessage.success(res.msg);
location.href = import.meta.env.VITE_APP_CONTEXT_PATH + 'index';
};
const handleError = (error: any) => {
ElMessage.error(error.message);
location.href = import.meta.env.VITE_APP_CONTEXT_PATH + 'index';
};
const callbackByCode = async (data: LoginData) => {
try {
const res = await callback(data);
await processResponse(res);
loading.value = false; loading.value = false;
setToken(res.msg); } catch (error) {
ElMessage.success('登录成功'); handleError(error);
location.href = import.meta.env.VITE_APP_CONTEXT_PATH + 'index'; }
}) };
.catch(() => {
const loginByCode = async (data: LoginData) => {
try {
const res = await login(data);
await processResponse(res);
loading.value = false; loading.value = false;
} catch (error) {
handleError(error);
}
};
const init = async () => {
const data: LoginData = {
socialCode: code,
socialState: state,
tenantId: tenantId,
source: source,
clientId: 'e5cd7e4891bf95d1d19206ce24a7b32e',
grantType: 'social'
};
if (!getToken()) {
await loginByCode(data);
} else {
await callbackByCode(data);
}
};
onMounted(() => {
nextTick(() => {
init();
}); });
});
</script> </script>

View File

@ -181,4 +181,5 @@ const router = createRouter({
} }
}); });
export default router; export default router;

View File

@ -4,7 +4,8 @@
<h3 class="title">RuoYi-Vue-Plus多租户管理系统</h3> <h3 class="title">RuoYi-Vue-Plus多租户管理系统</h3>
<el-form-item prop="tenantId" v-if="tenantEnabled"> <el-form-item prop="tenantId" v-if="tenantEnabled">
<el-select v-model="loginForm.tenantId" filterable placeholder="请选择/输入公司名称" style="width: 100%"> <el-select v-model="loginForm.tenantId" filterable placeholder="请选择/输入公司名称" style="width: 100%">
<el-option v-for="item in tenantList" :key="item.tenantId" :label="item.companyName" :value="item.tenantId"></el-option> <el-option v-for="item in tenantList" :key="item.tenantId" :label="item.companyName"
:value="item.tenantId"></el-option>
<template #prefix><svg-icon icon-class="company" class="el-input__icon input-icon" /></template> <template #prefix><svg-icon icon-class="company" class="el-input__icon input-icon" /></template>
</el-select> </el-select>
</el-form-item> </el-form-item>
@ -14,12 +15,14 @@
</el-input> </el-input>
</el-form-item> </el-form-item>
<el-form-item prop="password"> <el-form-item prop="password">
<el-input v-model="loginForm.password" type="password" size="large" auto-complete="off" placeholder="密码" @keyup.enter="handleLogin"> <el-input v-model="loginForm.password" type="password" size="large" auto-complete="off" placeholder="密码"
@keyup.enter="handleLogin">
<template #prefix><svg-icon icon-class="password" class="el-input__icon input-icon" /></template> <template #prefix><svg-icon icon-class="password" class="el-input__icon input-icon" /></template>
</el-input> </el-input>
</el-form-item> </el-form-item>
<el-form-item prop="code" v-if="captchaEnabled"> <el-form-item prop="code" v-if="captchaEnabled">
<el-input v-model="loginForm.code" size="large" auto-complete="off" placeholder="验证码" style="width: 63%" @keyup.enter="handleLogin"> <el-input v-model="loginForm.code" size="large" auto-complete="off" placeholder="验证码" style="width: 63%"
@keyup.enter="handleLogin">
<template #prefix><svg-icon icon-class="validCode" class="el-input__icon input-icon" /></template> <template #prefix><svg-icon icon-class="validCode" class="el-input__icon input-icon" /></template>
</el-input> </el-input>
<div class="login-code"> <div class="login-code">
@ -177,6 +180,12 @@ const initTenantList = async () => {
} }
} }
} }
//
watch(() => loginForm.value.tenantId, (val: string) => {
Cookies.set("tenantId", loginForm.value.tenantId, { expires: 30 })
});
/** /**
* 第三方登录 * 第三方登录
* @param type * @param type
@ -185,7 +194,7 @@ const doSocialLogin = (type: string) => {
authBinding(type).then((res: any) => { authBinding(type).then((res: any) => {
if (res.code === 200) { if (res.code === 200) {
window.location.href = res.msg; window.location.href = res.msg;
} else { } else {
ElMessage.error(res.msg); ElMessage.error(res.msg);
} }
}); });