This commit is contained in:
qiangyanwen 2022-08-14 16:34:29 +08:00
parent 922d54f38f
commit 00a00161fa
5 changed files with 131 additions and 75 deletions

11
src/api/user.js Normal file
View File

@ -0,0 +1,11 @@
import request from "@/utils/request";
export const Login =(data)=>{
return request({
url: "/login",
method: "post",
data: data,
})
}

View File

@ -28,7 +28,7 @@
<template #overlay> <template #overlay>
<a-menu> <a-menu>
<a-menu-item> <a-menu-item>
<a href="javascript:" @click="login">注销</a> <a href="javascript:" @click="logout">注销</a>
</a-menu-item> </a-menu-item>
</a-menu> </a-menu>
</template> </template>
@ -45,7 +45,7 @@
</div> </div>
</a-layout-content> </a-layout-content>
<a-layout-footer style="text-align: center"> <a-layout-footer style="text-align: center">
自动化测试研发 ©2018 研发部 自动化测试研发 ©2022 研发部
</a-layout-footer> </a-layout-footer>
</a-layout> </a-layout>
</a-layout> </a-layout>
@ -60,7 +60,7 @@ import {
DownOutlined, DownOutlined,
} from '@ant-design/icons-vue'; } from '@ant-design/icons-vue';
import {useRouter,useRoute} from "vue-router"; import {useRouter,useRoute} from "vue-router";
import { defineComponent, ref,watch } from 'vue'; import { defineComponent, ref } from 'vue';
import {useStore} from "@/store"; import {useStore} from "@/store";
import {storeToRefs} from "pinia"; import {storeToRefs} from "pinia";
@ -86,8 +86,9 @@ export default defineComponent({
const goTopage=(item)=>{ const goTopage=(item)=>{
router.push('/'+item.key).catch((err)=>err) router.push('/'+item.key).catch((err)=>err)
} }
const login =()=>{ const logout =()=>{
//cookie //cookie
window.sessionStorage.clear()
router.push("/login") router.push("/login")
} }
return { return {
@ -96,7 +97,7 @@ export default defineComponent({
container, container,
goTopage, goTopage,
route, route,
login, logout,
username, username,
}; };
}, },

View File

@ -3,6 +3,8 @@ import Layout from "@/components/Layout";
import Monit from "@/view/Monit"; import Monit from "@/view/Monit";
import User from "@/view/User"; import User from "@/view/User";
import Login from "@/view/Login"; import Login from "@/view/Login";
import {message} from "ant-design-vue";
const routes = [ const routes = [
{ {
path: "/", path: "/",
@ -44,4 +46,17 @@ const router = createRouter({
routes routes
}) })
router.beforeEach((to,from,next)=>{
const token = window.sessionStorage.getItem('token')
if (to.path ==="/login")return next()
if (!token && to.path ==='/monit'){
message.error("token失效,请重新登录")
next('/login')
}else{
next()
}
}
)
export default router export default router

26
src/utils/request.js Normal file
View File

@ -0,0 +1,26 @@
import axios from 'axios';
import {message} from "ant-design-vue";
import {useRouter} from "vue-router";
const service = axios.create({
baseURL: 'http://192.168.0.103:8000/api',
timeout: 5000
});
const router = useRouter()
service.interceptors.request.use(function (config) {
console.log(config)
const token = window.sessionStorage.getItem("token")
if (token !== "" || token != null || token != '') {
config.headers["Authorization"] = "Bearer " +token
}else{
message.error("没有token,请登录")
router.replace({
path: "/login"
})
}
return config
})
export default service;

View File

@ -1,47 +1,52 @@
<template> <template>
<div class="container"> <div class="container">
<div class="loginBox"> <div class="loginBox">
<a-form class="loginForm" :model="formdata" <a-form class="loginForm" :model="userData"
:rules="rules" ref="formRef" > :rules="rules" ref="formRef">
<a-form-item <a-form-item
name="username" name="username"
> >
<a-input placeholder="请输入用户名" v-model:value="formdata.username"> <a-input placeholder="请输入用户名" v-model:value="userData.username">
<template #prefix><UserOutlined style="color: rgba(0, 0, 0, 0.25)" /></template> <template #prefix>
</a-input> <UserOutlined style="color: rgba(0, 0, 0, 0.25)"/>
</a-form-item> </template>
<a-form-item name="password" > </a-input>
<a-input-password placeholder="请输入密码" v-model:value="formdata.password" v-on:keyup.enter=""> </a-form-item>
<template #prefix><LockOutlined style="color: rgba(0, 0, 0, 0.25)" /></template> <a-form-item name="password">
</a-input-password> <a-input-password placeholder="请输入密码" v-model:value="userData.password" v-on:keyup.enter="logins">
</a-form-item> <template #prefix>
<a-form-item class="loginBtn"> <LockOutlined style="color: rgba(0, 0, 0, 0.25)"/>
<a-button type="primary" style="margin: 10px" @click="">登录</a-button> </template>
<a-button type="info" style="margin: 10px" @click.prevent="close">取消</a-button> </a-input-password>
</a-form-item> </a-form-item>
</a-form> <a-form-item class="loginBtn">
<a-button type="primary" style="margin: 10px" @click="logins">登录</a-button>
<a-button type="info" style="margin: 10px" @click.prevent="close">取消</a-button>
</a-form-item>
</a-form>
</div>
</div> </div>
</div>
</template> </template>
<script> <script>
import { UserOutlined, LockOutlined } from '@ant-design/icons-vue'; import {UserOutlined, LockOutlined} from '@ant-design/icons-vue';
import { useRouter } from 'vue-router' import {useRouter} from 'vue-router'
import {reactive,toRaw,ref} from 'vue' import {reactive, toRaw, ref} from 'vue'
import { message } from 'ant-design-vue'; import {message} from 'ant-design-vue';
import {useStore} from "@/store"; import {useStore} from "@/store";
import {Login} from '@/api/user';
export default { export default {
name: "login", name: "login",
components:{ components: {
UserOutlined, UserOutlined,
LockOutlined, LockOutlined,
}, },
setup(){ setup() {
const formdata=reactive({ const userData = reactive({
username: "", username: "",
password: "", password: "",
}) })
@ -51,89 +56,87 @@ export default {
const router = useRouter() const router = useRouter()
const rules = { const rules = {
username:{ username: {
required: true, required: true,
min:2, min: 2,
max:12, max: 12,
message: "用户名在3-12个字符之间" message: "用户名在3-12个字符之间"
}, },
password:{ password: {
required: true, message: '请输入密码',trigger:'blur' required: true, message: '请输入密码', trigger: 'blur'
} }
} }
const close = () => { const close = () => {
formRef.value.resetFields(); formRef.value.resetFields();
}; };
const mon = useStore() const mon = useStore()
const Check =(username)=>{ const Check = (username) => {
mon.Update(username) mon.Update(username)
} }
// const logins = () => { const logins = () => {
// formRef.value.validate().then(()=>{ formRef.value.validate().then(() => {
// Login(formdata).then((rep)=>{ const formData = new FormData()
// if (rep.data.code !==200){ formData.append("username", userData.username)
// message.error(rep.data.msg) formData.append("password", userData.password)
// }else{ Login(formData).then((rep) => {
// message.success(rep.data.msg) if (rep.data.code !== 200) {
// console.log(rep.data) message.error(rep.data.msg)
// window.sessionStorage.setItem('token',rep.data.data.token) } else {
// router.push('/admin/index') message.success(rep.data.message)
// } Check(rep.data.user.username)
// }) window.sessionStorage.setItem('token', rep.data.access_token)
// }).catch((err)=>{ router.push('/monit')
// message.error(",!",err) }
// }) })
// } }).catch((err) => {
message.error("输入非法数据,请重新输入!", err)
})
}
return { return {
formdata, userData,
close, close,
rules, rules,
formRef, formRef,
logins
} }
}, },
} }
</script > </script>
<style scoped> <style scoped>
.container{ .container {
height: 100%; height: 100%;
background-color: #282C34; background-color: #282C34;
background-image: url("../assets/css/images/background.jpeg"); background-image: url("../assets/css/images/background.jpeg");
} }
.loginBox{
.loginBox {
width: 450px; width: 450px;
height: 300px; height: 300px;
background-color: rgb(50, 109, 146); background-color: rgb(50, 109, 146);
position: absolute; position: absolute;
top: 50%; top: 50%;
left: 80%; left: 80%;
transform: translate(-50%,-50%); transform: translate(-50%, -50%);
border-radius: 9px; border-radius: 9px;
} }
.loginForm{
.loginForm {
width: 100%; width: 100%;
position: absolute; position: absolute;
bottom: 10%; bottom: 10%;
padding: 0 20px; padding: 0 20px;
box-sizing: border-box; box-sizing: border-box;
} }
.loginBtn{
.loginBtn {
display: flex; display: flex;
justify-content: flex-end; justify-content: flex-end;
} }