| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  | <template> | 
					
						
							|  |  |  |   <div class="login"> | 
					
						
							|  |  |  |     <el-form ref="loginForm" :model="loginForm" :rules="loginRules" class="login-form"> | 
					
						
							|  |  |  |       <h3 class="title">若依后台管理系统</h3> | 
					
						
							|  |  |  |       <el-form-item prop="username"> | 
					
						
							|  |  |  |         <el-input v-model="loginForm.username" type="text" auto-complete="off" placeholder="账号"> | 
					
						
							|  |  |  |           <svg-icon slot="prefix" icon-class="user" class="el-input__icon input-icon" /> | 
					
						
							|  |  |  |         </el-input> | 
					
						
							|  |  |  |       </el-form-item> | 
					
						
							|  |  |  |       <el-form-item prop="password"> | 
					
						
							|  |  |  |         <el-input | 
					
						
							|  |  |  |           v-model="loginForm.password" | 
					
						
							|  |  |  |           type="password" | 
					
						
							|  |  |  |           auto-complete="off" | 
					
						
							|  |  |  |           placeholder="密码" | 
					
						
							|  |  |  |           @keyup.enter.native="handleLogin" | 
					
						
							|  |  |  |         > | 
					
						
							|  |  |  |           <svg-icon slot="prefix" icon-class="password" class="el-input__icon input-icon" /> | 
					
						
							|  |  |  |         </el-input> | 
					
						
							|  |  |  |       </el-form-item> | 
					
						
							| 
									
										
										
										
											2021-07-13 10:30:40 +08:00
										 |  |  |       <el-form-item prop="code" v-if="captchaOnOff"> | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  |         <el-input | 
					
						
							|  |  |  |           v-model="loginForm.code" | 
					
						
							|  |  |  |           auto-complete="off" | 
					
						
							|  |  |  |           placeholder="验证码" | 
					
						
							|  |  |  |           style="width: 63%" | 
					
						
							|  |  |  |           @keyup.enter.native="handleLogin" | 
					
						
							|  |  |  |         > | 
					
						
							|  |  |  |           <svg-icon slot="prefix" icon-class="validCode" class="el-input__icon input-icon" /> | 
					
						
							|  |  |  |         </el-input> | 
					
						
							|  |  |  |         <div class="login-code"> | 
					
						
							| 
									
										
										
										
											2020-07-23 11:17:04 +08:00
										 |  |  |           <img :src="codeUrl" @click="getCode" class="login-code-img"/> | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  |         </div> | 
					
						
							|  |  |  |       </el-form-item> | 
					
						
							|  |  |  |       <el-checkbox v-model="loginForm.rememberMe" style="margin:0px 0px 25px 0px;">记住密码</el-checkbox> | 
					
						
							|  |  |  |       <el-form-item style="width:100%;"> | 
					
						
							|  |  |  |         <el-button | 
					
						
							|  |  |  |           :loading="loading" | 
					
						
							|  |  |  |           size="medium" | 
					
						
							|  |  |  |           type="primary" | 
					
						
							|  |  |  |           style="width:100%;" | 
					
						
							|  |  |  |           @click.native.prevent="handleLogin" | 
					
						
							|  |  |  |         > | 
					
						
							|  |  |  |           <span v-if="!loading">登 录</span> | 
					
						
							|  |  |  |           <span v-else>登 录 中...</span> | 
					
						
							|  |  |  |         </el-button> | 
					
						
							|  |  |  |       </el-form-item> | 
					
						
							|  |  |  |     </el-form> | 
					
						
							|  |  |  |     <!--  底部  --> | 
					
						
							|  |  |  |     <div class="el-login-footer"> | 
					
						
							| 
									
										
										
										
											2021-01-04 17:49:52 +08:00
										 |  |  |       <span>Copyright © 2018-2021 ruoyi.vip All Rights Reserved.</span> | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  |     </div> | 
					
						
							|  |  |  |   </div> | 
					
						
							|  |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script> | 
					
						
							|  |  |  | import { getCodeImg } from "@/api/login"; | 
					
						
							|  |  |  | import Cookies from "js-cookie"; | 
					
						
							| 
									
										
										
										
											2019-11-20 11:53:04 +08:00
										 |  |  | import { encrypt, decrypt } from '@/utils/jsencrypt' | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | export default { | 
					
						
							|  |  |  |   name: "Login", | 
					
						
							|  |  |  |   data() { | 
					
						
							|  |  |  |     return { | 
					
						
							|  |  |  |       codeUrl: "", | 
					
						
							|  |  |  |       cookiePassword: "", | 
					
						
							|  |  |  |       loginForm: { | 
					
						
							|  |  |  |         username: "admin", | 
					
						
							|  |  |  |         password: "admin123", | 
					
						
							|  |  |  |         rememberMe: false, | 
					
						
							|  |  |  |         code: "", | 
					
						
							|  |  |  |         uuid: "" | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       loginRules: { | 
					
						
							|  |  |  |         username: [ | 
					
						
							|  |  |  |           { required: true, trigger: "blur", message: "用户名不能为空" } | 
					
						
							|  |  |  |         ], | 
					
						
							|  |  |  |         password: [ | 
					
						
							|  |  |  |           { required: true, trigger: "blur", message: "密码不能为空" } | 
					
						
							|  |  |  |         ], | 
					
						
							|  |  |  |         code: [{ required: true, trigger: "change", message: "验证码不能为空" }] | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       loading: false, | 
					
						
							| 
									
										
										
										
											2021-07-13 10:30:40 +08:00
										 |  |  |       captchaOnOff: true, | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  |       redirect: undefined | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   watch: { | 
					
						
							|  |  |  |     $route: { | 
					
						
							|  |  |  |       handler: function(route) { | 
					
						
							|  |  |  |         this.redirect = route.query && route.query.redirect; | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       immediate: true | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   created() { | 
					
						
							|  |  |  |     this.getCode(); | 
					
						
							|  |  |  |     this.getCookie(); | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   methods: { | 
					
						
							|  |  |  |     getCode() { | 
					
						
							|  |  |  |       getCodeImg().then(res => { | 
					
						
							| 
									
										
										
										
											2021-07-13 10:30:40 +08:00
										 |  |  |         this.captchaOnOff = res.captchaOnOff === undefined ? true : res.captchaOnOff; | 
					
						
							|  |  |  |         if (this.captchaOnOff) { | 
					
						
							|  |  |  |           this.codeUrl = "data:image/gif;base64," + res.img; | 
					
						
							|  |  |  |           this.loginForm.uuid = res.uuid; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  |       }); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     getCookie() { | 
					
						
							|  |  |  |       const username = Cookies.get("username"); | 
					
						
							|  |  |  |       const password = Cookies.get("password"); | 
					
						
							|  |  |  |       const rememberMe = Cookies.get('rememberMe') | 
					
						
							|  |  |  |       this.loginForm = { | 
					
						
							|  |  |  |         username: username === undefined ? this.loginForm.username : username, | 
					
						
							| 
									
										
										
										
											2019-11-20 11:53:04 +08:00
										 |  |  |         password: password === undefined ? this.loginForm.password : decrypt(password), | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  |         rememberMe: rememberMe === undefined ? false : Boolean(rememberMe) | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     handleLogin() { | 
					
						
							|  |  |  |       this.$refs.loginForm.validate(valid => { | 
					
						
							|  |  |  |         if (valid) { | 
					
						
							|  |  |  |           this.loading = true; | 
					
						
							|  |  |  |           if (this.loginForm.rememberMe) { | 
					
						
							|  |  |  |             Cookies.set("username", this.loginForm.username, { expires: 30 }); | 
					
						
							| 
									
										
										
										
											2019-11-20 11:53:04 +08:00
										 |  |  |             Cookies.set("password", encrypt(this.loginForm.password), { expires: 30 }); | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  |             Cookies.set('rememberMe', this.loginForm.rememberMe, { expires: 30 }); | 
					
						
							|  |  |  |           } else { | 
					
						
							|  |  |  |             Cookies.remove("username"); | 
					
						
							|  |  |  |             Cookies.remove("password"); | 
					
						
							|  |  |  |             Cookies.remove('rememberMe'); | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2020-12-15 10:04:09 +08:00
										 |  |  |           this.$store.dispatch("Login", this.loginForm).then(() => { | 
					
						
							|  |  |  |             this.$router.push({ path: this.redirect || "/" }).catch(()=>{}); | 
					
						
							|  |  |  |           }).catch(() => { | 
					
						
							|  |  |  |             this.loading = false; | 
					
						
							| 
									
										
										
										
											2021-07-13 10:30:40 +08:00
										 |  |  |             if (this.captchaOnOff) { | 
					
						
							|  |  |  |               this.getCode(); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2020-12-15 10:04:09 +08:00
										 |  |  |           }); | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  |         } | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <style rel="stylesheet/scss" lang="scss"> | 
					
						
							|  |  |  | .login { | 
					
						
							|  |  |  |   display: flex; | 
					
						
							|  |  |  |   justify-content: center; | 
					
						
							|  |  |  |   align-items: center; | 
					
						
							|  |  |  |   height: 100%; | 
					
						
							| 
									
										
										
										
											2020-12-07 14:13:02 +08:00
										 |  |  |   background-image: url("../assets/images/login-background.jpg"); | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  |   background-size: cover; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .title { | 
					
						
							|  |  |  |   margin: 0px auto 30px auto; | 
					
						
							|  |  |  |   text-align: center; | 
					
						
							|  |  |  |   color: #707070; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .login-form { | 
					
						
							|  |  |  |   border-radius: 6px; | 
					
						
							|  |  |  |   background: #ffffff; | 
					
						
							|  |  |  |   width: 400px; | 
					
						
							|  |  |  |   padding: 25px 25px 5px 25px; | 
					
						
							|  |  |  |   .el-input { | 
					
						
							|  |  |  |     height: 38px; | 
					
						
							|  |  |  |     input { | 
					
						
							|  |  |  |       height: 38px; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .input-icon { | 
					
						
							|  |  |  |     height: 39px; | 
					
						
							|  |  |  |     width: 14px; | 
					
						
							|  |  |  |     margin-left: 2px; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .login-tip { | 
					
						
							|  |  |  |   font-size: 13px; | 
					
						
							|  |  |  |   text-align: center; | 
					
						
							|  |  |  |   color: #bfbfbf; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .login-code { | 
					
						
							|  |  |  |   width: 33%; | 
					
						
							|  |  |  |   height: 38px; | 
					
						
							|  |  |  |   float: right; | 
					
						
							|  |  |  |   img { | 
					
						
							|  |  |  |     cursor: pointer; | 
					
						
							|  |  |  |     vertical-align: middle; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .el-login-footer { | 
					
						
							|  |  |  |   height: 40px; | 
					
						
							|  |  |  |   line-height: 40px; | 
					
						
							|  |  |  |   position: fixed; | 
					
						
							|  |  |  |   bottom: 0; | 
					
						
							|  |  |  |   width: 100%; | 
					
						
							|  |  |  |   text-align: center; | 
					
						
							|  |  |  |   color: #fff; | 
					
						
							|  |  |  |   font-family: Arial; | 
					
						
							|  |  |  |   font-size: 12px; | 
					
						
							|  |  |  |   letter-spacing: 1px; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2020-07-23 11:17:04 +08:00
										 |  |  | .login-code-img { | 
					
						
							|  |  |  |   height: 38px; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  | </style> |