123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206 |
- <template>
- <div class='full-screen flex flex-center '>
- <el-card class='login'>
- <div class='flex flex-center' style='width: 100%'>
- <div class='flex-child-average flex flex-center left'>
- <div class='flex flex-justify-start flex-align-start full-height '>
- <img src='@/assets/img/logo.png' class='padding-14 logo'/>
- <img src='https://hooray.gitee.io/fantastic-admin-example/assets/login-banner.a565fac8.png' class='logo-main' />
- </div>
- </div>
- <div class='flex-child-average right'>
- <div class='padding-20'>
- <span class='font-24 black bold '>欢迎来到梧桐树云项目管理云平台👏</span>
- <el-form class='form' :model="form" :rules="rules" ref='loginForm'>
- <el-form-item prop='name'>
- <el-input
- v-model='form.name'
- size='large'
- placeholder="用户名"
- prefix-icon="Avatar"
- />
- </el-form-item>
- <el-form-item prop='pass'>
- <el-input
- v-model='form.pass'
- size='large'
- placeholder="密码"
- :type='flag ? "text" : "password"'
- prefix-icon="WalletFilled">
- <template v-slot:suffix>
- <div @click='flag=!flag' class='pointer'>
- <el-icon v-if='!flag'><Hide /></el-icon>
- <el-icon v-else><View /></el-icon>
- </div>
- </template>
- </el-input>
- </el-form-item>
- <el-form-item prop='code'>
- <el-input
- v-model='form.code'
- size='large'
- placeholder="验证码"
- prefix-icon="Refresh"
- class='append'
- >
- <template v-slot:append>
- <img :src='code' class='pic' style='height: 40px;background-color: red;background-blend-mode: lighten;' />
- </template>
- </el-input>
- </el-form-item>
- <el-form-item>
- <div class='flex flex-align-center flex-justify-between full-width'>
- <div></div>
- <el-link type='primary' :underline='false' class='font-12'>忘记密码?</el-link>
- </div>
- </el-form-item>
- </el-form>
- <el-button type='primary' class='full-width' size='large' @click='submint'>登录</el-button>
- <div class='mt-10 flex flex-center'>
- <span>还没账户?</span>
- <el-link type='primary' :underline='false'>注册账户</el-link>
- </div>
- <el-divider/>
- <div class='flex flex-col'>
- <span class='grey-6'>
- 由梧桐经济学院提供技术支持
- </span>
- <div>
- <el-button size='small' type='primary' plain class='mt-10' @click='loginAdmin'>admin</el-button>
- </div>
- </div>
- </div>
- </div>
- </div>
- </el-card>
- </div>
- </template>
- <route>
- {
- meta: {
- layout: 'empty',
- },
- }
- </route>
- <script>
- import md5 from 'js-md5'
- import { useStore } from '@/store/user.js'
- import { setToken } from '../utils/auth.js'
- export default {
- name: 'login',
- setup () {
- const user = useStore()
- return { user }
- },
- data () {
- return {
- flag: false,
- form: {
- name: '',
- pass: ''
- },
- rules: {
- name: [
- { required: true, message: '请输入用户名', trigger: 'blur' },
- { min: 3, max: 12, message: '长度在 3 到 12 个字符', trigger: 'blur' }
- ],
- pass: [
- { required: true, message: '请输入密码', trigger: 'blur' },
- { min: 3, max: 12, message: '长度在 3 到 12 个字符', trigger: 'blur' }
- ],
- code: [
- { required: true, message: '请输入验证码', trigger: 'blur' },
- { min: 5, max: 5, message: '验证码不正确', trigger: 'blur' }
- ]
- },
- code: '',
- header: ''
- }
- },
- created () {
- this.init()
- },
- methods: {
- init () {
- this.$api.login.captcha().then(res => {
- this.code = res.image
- this.header = res.key
- })
- },
- submint () {
- this.$refs.loginForm.validate((res) => {
- if (res) {
- const params = { tenantId: '000000', username: this.form.name, password: md5(this.form.pass), grant_type: 'captcha', scope: 'all', type: 'account' }
- const header = { captchaKey: this.header, captchaCode: this.form.code }
- this.$api.login.login(params, header).then(res => {
- if (res.error_description) {
- this.$message.error(res.error_description)
- this.init()
- } else {
- // 保存信息
- this.user.setUserInfo(res)
- setToken(res.access_token)
- this.$router.replace('/')
- }
- })
- } else {
- return false
- }
- })
- },
- loginAdmin () {
- this.form.name = 'admin'
- this.form.pass = 'admin'
- }
- }
- }
- </script>
- <style lang='scss' scoped>
- .login{
- :deep(.el-card__body){
- padding: 0 !important;
- };
- padding: 0;
- display: flex;
- top: 50%;
- left: 50%;
- border-radius: 10px;
- background-color: white;
- width: 950px;
- height: 500px;
- .left {
- background-color: #F5F7FA;
- height: 500px;
- .logo {
- width: 45px;
- height: 45px;
- border-radius: 50%;
- }
- .logo-main {
- width: 100%;
- margin-top: 70px;
- margin-left: -80px;
- }
- }
- .right {
- background-color: white;
- height: 500px;
- .form{
- margin-top: 30px;
- }
- }
- }
- .append {
- :deep(.el-input-group__append){
- background-color: white;
- }
- .pic {
- border-top: #DDDFE5 1px solid;
- border-bottom: #DDDFE5 1px solid;
- }
- }
- </style>
|