登录端口添加

This commit is contained in:
龚皓 2024-09-30 15:52:11 +08:00
parent 31ece3ea1f
commit 76dfe72832
1 changed files with 167 additions and 111 deletions

View File

@ -1,148 +1,204 @@
<script lang="ts" setup> <script lang="ts" setup>
import { reactive } from 'vue' import { reactive, ref, onMounted } from 'vue';
import { useRouter } from 'vue-router' import { useRoute, useRouter } from 'vue-router';
import {ElMessage} from 'element-plus' import { BoxApi } from '@/utils/boxApi';
import { Lock, User } from '@element-plus/icons-vue'; import { User, Lock } from '@element-plus/icons-vue';
import { useSuperbox } from '@/utils/Superbox'
import { useSetToken } from '@/utils/misc';
const router = useRouter(); const router = useRouter();
const superbox = useSuperbox(); const route = useRoute();
const loginForm = reactive({ const loginForm = reactive({
username: '', username: '',
password: '' password: '',
address: '',
port: '',
remember: false // ""
}); });
const setToken = useSetToken(); const errorMessage = ref('');
const username = ref(localStorage.getItem('username') || '');
const alertToken = ref('');
const cookless = ref(false);
//
let apiInstance: BoxApi | null = null;
//
onMounted(() => {
const savedUsername = localStorage.getItem('username');
const savedPassword = localStorage.getItem('rememberedPassword');
const savedAddress = localStorage.getItem('rememberedAddress');
const savedPort = localStorage.getItem('rememberedPort');
if (savedUsername && savedPassword && savedAddress && savedPort) {
loginForm.username = savedUsername;
loginForm.password = savedPassword;
loginForm.address = savedAddress;
loginForm.port = savedPort;
loginForm.remember = true; //
}
});
const onSubmit = async () => { const onSubmit = async () => {
try { try {
const token = await superbox.login(loginForm.username, loginForm.password, false); //
if (token) { if (!loginForm.address || !loginForm.port) {
setToken(token); errorMessage.value = '请输入服务器地址和端口';
router.push('/'); return;
}
} catch (error) {
ElMessage(
{
message: '用户名或密码错误,登录失败',
type: 'error',
duration: 5000
}
);
console.log(error);
} }
// SuperboxApi
apiInstance = new BoxApi(loginForm.address, parseInt(loginForm.port));
// SuperboxApi login cookless false
const apiToken = await apiInstance.login(loginForm.username, loginForm.password,false);
// token
localStorage.setItem('alertToken', apiToken);
// localStorage
if (loginForm.remember) {
localStorage.setItem('username', loginForm.username);
localStorage.setItem('rememberedPassword', loginForm.password);
localStorage.setItem('rememberedAddress', loginForm.address);
localStorage.setItem('rememberedPort', loginForm.port);
} else {
//
localStorage.removeItem('rememberedPassword');
localStorage.removeItem('rememberedAddress');
localStorage.removeItem('rememberedPort');
}
//
let redirect = route.query.redirect;
if (Array.isArray(redirect)) {
redirect = redirect[0]; // redirect
}
router.push(redirect || '/'); // redirect 使 '/'
} catch (error) {
//
errorMessage.value = '用户名或密码错误,或者连接服务器失败';
}
}; };
const onReset = () => { const onReset = () => {
loginForm.username = ''; loginForm.username = '';
loginForm.password = ''; loginForm.password = '';
loginForm.address = '';
loginForm.port = '';
loginForm.remember = false; //
errorMessage.value = '';
}; };
</script> </script>
<template> <template>
<div class="main-layout"> <div class="main-layout">
<div class="login-form">
<div class="login-form"> <div class="login-header">
<div class="login-header"> <el-row justify="center">
<el-row justify="center"> <el-image src="/logo.png" fit="contain" />
<el-image src="./logo.png" fit="contain" /> </el-row>
</el-row> </div>
</div> <div class="login-body">
<div class="login-body"> <el-form :model="loginForm" style="max-width: 600px;">
<el-form :model="loginForm" style="max-width: 600px;"> <el-form-item>
<el-input v-model="loginForm.address" placeholder="服务器地址" />
<el-form-item> </el-form-item>
<el-input v-model="loginForm.username" placeholder="用户名" clearable> <el-form-item>
<template #prefix> <el-input v-model="loginForm.port" placeholder="端口" type="number" />
<el-icon class="el-input__icon"> </el-form-item>
<User /> <el-form-item>
</el-icon> <el-input v-model="loginForm.username" placeholder="用户名">
</template> <template #prefix>
</el-input> <el-icon class="el-input__icon">
</el-form-item> <User />
</el-icon>
<el-form-item> </template>
<el-input v-model="loginForm.password" placeholder="密码" type="password" show-password clearable> </el-input>
<template #prefix> </el-form-item>
<el-icon class="el-input__icon"> <el-form-item>
<Lock /> <el-input v-model="loginForm.password" placeholder="密码" type="password">
</el-icon> <template #prefix>
</template> <el-icon class="el-input__icon">
</el-input> <Lock />
</el-form-item> </el-icon>
<el-row justify="end"> </template>
<el-form-item size="small" :gutter="30"> </el-input>
<el-button type="primary" @click="onReset" plain>重置</el-button> </el-form-item>
<el-button type="primary" @click="onSubmit">登录</el-button> <!-- 添加记住密码复选框 -->
</el-form-item> <el-form-item>
</el-row> <el-checkbox v-model="loginForm.remember">记住密码</el-checkbox>
</el-form> </el-form-item>
</div> <el-row justify="end">
<el-form-item size="small" :gutter="30">
<div class="login-footer"> <el-button type="primary" @click="onReset" plain>重置</el-button>
<el-row justify="end"> <el-button type="primary" @click="onSubmit">登录</el-button>
<el-text class="plain-text">Powered by TuringAI</el-text> </el-form-item>
</el-row> </el-row>
</div> <el-row justify="center">
<el-text class="error-message">{{ errorMessage }}</el-text>
</div> </el-row>
</el-form>
</div>
<div class="login-footer">
<el-row justify="end">
<el-text class="plain-text">Powered by TuringAI</el-text>
</el-row>
</div>
</div> </div>
</div>
</template> </template>
<style scoped> <style scoped>
.main-layout { .main-layout {
position: absolute; position: absolute;
top: 0; top: 0;
left: 0; left: 0;
width: 100%; width: 100%;
height: 100%; height: 100%;
background-image: url('./login-bg.jpg'); background-image: url('/login-bg.jpg');
background-size: cover; background-size: cover;
} }
.login-form { .login-form {
min-width: 350px; min-width: 350px;
position: absolute; position: absolute;
top: 50%; top: 50%;
left: 50%; left: 50%;
transform: translate(-50%, -50%); transform: translate(-50%, -50%);
border-radius: 10px; border-radius: 10px;
background-color: #01111863; background-color: #01111863;
} }
.login-body { .login-body {
padding-top: 30px; padding-top: 30px;
padding-bottom: 5px; padding-bottom: 5px;
padding-left: 30px; padding-left: 30px;
padding-right: 30px; padding-right: 30px;
} }
.login-header { .login-header {
padding-top: 15px; padding-top: 15px;
padding-bottom: 15px; padding-bottom: 15px;
background-color: #01111863; background-color: #01111863;
border-radius: 10px 10px 0px 0px; border-radius: 10px 10px 0px 0px;
} }
.login-footer { .login-footer {
padding-top: 15px; padding-top: 15px;
padding-bottom: 20px; padding-bottom: 20px;
padding-right: 30px; padding-right: 30px;
padding-left: 30px; padding-left: 30px;
background-color: #01111863; background-color: #01111863;
border-radius: 0px 0px 10px 10px; border-radius: 0px 0px 10px 10px;
}
.main-title {
color: #c2c8fd;
} }
.plain-text { .plain-text {
color: #9a9db3; color: #9a9db3;
} }
</style>
.error-message {
color: red;
}
</style>