You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

174 lines
5.4 KiB

<template>
<div class="site-wrapper site-page--login">
<div style="display: flex;height: 100vh">
<div class="login-bg"></div>
<div style="width: 35%">
<div style="height: 27vh;">
<div style="text-align: right;padding: 0px 20px">
<img width="60%" height="72" style="object-fit: contain" src="~@/assets/img/ckp.png">
</div>
</div>
<div style="padding: 30px 130px">
<h3 class="login-title">用户登陆</h3>
<el-form :model="dataForm" :rules="dataRule" ref="dataForm" @keyup.enter.native="dataFormSubmit()" status-icon>
<el-form-item prop="userName">
<el-input v-model="dataForm.userName" placeholder="帐号" size="large"></el-input>
</el-form-item>
<el-form-item prop="password" style="margin-top: 20px">
<el-input v-model="dataForm.password" type="password" placeholder="密码" size="large"></el-input>
</el-form-item>
<el-form-item style="margin-top: 20px">
<el-button style="width: 100%" type="primary" @click="dataFormSubmit()">登录</el-button>
</el-form-item>
</el-form>
</div>
</div>
</div>
</div>
</template>
<script>
import {getConfigParams} from '@/api/sysConfig.js'
import { getUUID } from '@/utils'
export default {
data () {
return {
src: 'http://127.0.0.1/upload/ifs.png',
dataForm: {
userName: '',
password: '',
uuid: '',
captcha: ''
},
dataRule: {
userName: [
{ required: true, message: '帐号不能为空', trigger: 'blur' }
],
password: [
{ required: true, message: '密码不能为空', trigger: 'blur' }
]
},
captchaPath: ''
}
},
computed: {
multiLanguage: {
get() {
return this.$store.state.user.multiLanguage
},
set(val) {
this.$store.commit('user/updateMultiLanguage', val)
}
},
authControl: {
get() {
return this.$store.state.user.authControl
},
set(val) {
this.$store.commit('user/updateAuthControl', val)
}
}
},
mounted() {
// 仅当 redirectPath 为空时设置
const redirectPath = this.$route.query.redirect || '/home';
if (!localStorage.getItem('redirectPath')) {
localStorage.setItem('redirectPath', redirectPath);
}
},
created () {
this.userName();
// 如果 redirectPath 已经存在,不要覆盖它
const currentPath = localStorage.getItem('redirectPath');
if (!currentPath) {
localStorage.setItem('redirectPath', this.$route.fullPath);
}
},
methods: {
// 获取上次登陆的用户名
userName(){
this.dataForm.userName = localStorage.getItem('userName')
},
// 提交表单
dataFormSubmit () {
this.$refs['dataForm'].validate((valid) => {
if (valid) {
this.$http({
url: this.$http.adornUrl('/sys/login'),
method: 'post',
data: this.$http.adornData({
'username': this.dataForm.userName,
'password': this.dataForm.password,
'uuid': this.dataForm.uuid
})
}).then(({data}) => {
if (data && data.code === 0) {
console.log('跳转前路径:', localStorage.getItem('redirectPath')); // 检查路径是否正确
this.$cookie.set('token', data.token)
// 动态跳转逻辑
const redirectPath = localStorage.getItem('redirectPath') || '';
// 设置需要判断的路径
const pathsToRedirect = ['/auth-authQuote', '/auth-authInquiry'];
if (pathsToRedirect.some(path => redirectPath.indexOf(path) !== -1)) {
this.$router.replace(redirectPath);
} else {
this.$router.replace({ name: 'home' });
}
console.log('Redirecting to:', redirectPath); // 调试输出
this.$i18n.locale=data.language
localStorage.setItem('locale', data.language)
localStorage.setItem('refresh', "0")
localStorage.setItem('userName', this.dataForm.userName)
this.getConfigParams()
} else {
this.$message.error(data.msg)
}
})
}
})
},
// 获取全局参数变量
getConfigParams() {
getConfigParams().then(({data}) => {
if (data && data.code == 0) {
localStorage.setItem('configParams', JSON.stringify(data.data))
// this.multiLanguage = JSON.parse(localStorage.getItem('configParams')).multiLanguage
// this.authControl = JSON.parse(localStorage.getItem('configParams')).authControl
}
})
},
}
}
</script>
<style lang="scss" scoped>
.site-wrapper.site-page--login {
.login-title {
font-size: 30px;
}
.login-main .el-input__inner{
margin-top: 10px;
height: 45px;
}
.el-button--medium {
margin-top: 0px;
padding: 5px 11px;
font-size: 16px;
border-radius: 4px;
}
.el-form-item {
margin-bottom: 5px;
}
}
.login-bg{
background-image: url(~@/assets/img/login_bg.jpg);
background-size: cover;
width: 65%;
}
</style>