先寫前端再寫后端
前提:idea+vue3+mybatis+springBoot3前后端分離實現對一張表的增刪改查(完整代碼版)-CSDN博客
項目地址
1.添加一個Login.vue視圖
<template><div class="login_container"><div class="login_box"><div style="padding:20px;background-color: white;margin-left: 100px;border-radius: 20px;box-shadow:0 0 10px rgba(0,0,0.1)"><el-form ref="formRef" :rules="data.rules" :model="data.form" style="width:400px" autocomplete="off" ><div style="margin-bottom:30px;font-size:20px;color:#0742b1;font-weight:bolder;text-align: center">歡迎登錄后臺管理系統</div><el-form-item style="margin-top: 20px;" prop="username" autocomplete="off"><el-input size="large" v-model="data.form.username" placeholder="請輸入賬號" prefix-icon="User" ></el-input></el-form-item><el-form-item prop="password"><el-input show-password="show-password" autocomplete="off" size="large" v-model="data.form.password" placeholder="請輸入密碼" prefix-icon="Lock"></el-input></el-form-item><div><el-button size="large" style="width: 48%" type="primary" @click="login()">登 錄</el-button><el-button size="large" style="width: 48%" type="info">取 消</el-button></div><div style="text-align: right;margin-top: 20px;">還沒有賬號?請<a style="color: #0742b1;text-decoration: none;" href="/register">注冊</a></div></el-form></div></div></div>
</template>
<script setup>
import { reactive,ref} from "vue";
import request from "@/utils/request.js";
import {ElMessage} from "element-plus";const res = ref()
const data = reactive({form:{username:'',password:''},rules:{username:[{required:true,message:'請輸入賬號',trigger:'blur'}],password:[{required:true,message:'請輸入密碼',trigger:'blur'}]}
})
const formRef = ref()
const login = () => {formRef.value.validate((valid) => {if (valid) {request.post('/employee/login', data.form).then(res => {if (res.code === '200') {localStorage.setItem("zwy-user",JSON.stringify(res.data))//把json對象轉換為字符串ElMessage.success('登錄成功');location.href = '/manager/home'} else {ElMessage.error(res.msg); // 顯示業務錯誤消息}}).catch(error => {if (error.response) {// 處理 HTTP 錯誤狀態碼(如 400)const { data } = error.response;if (data && data.msg) {ElMessage.error(data.msg); // 顯示后端返回的錯誤消息} else {ElMessage.error('請求失敗,請稍后重試');}} else {ElMessage.error('網絡請求失敗,請檢查網絡連接');}});}});
}</script>
<!--scoped表示當頁生效-->
<style scoped>
.login_container{height: 100vh;overflow:hidden;background-image: url("@/assets/login_bg.png");background-size:cover ;background-position: 0 -40px;
}
.login_box{width: 50%;height: 100%;display: flex;align-items: center;right: 0;position: absolute;
}
</style>
背景圖為下圖 位置background-image: url("@/assets/login_bg.png");
2.添加一個Register.vue視圖
<template><div class="Register_container"><div class="Register_box"><div style="padding:20px;background-color: white;margin-left: 100px;border-radius: 20px;box-shadow:0 0 10px rgba(0,0,0.1)"><el-form ref="formRef" :rules="data.rules" :model="data.form" style="width:400px" ><div style="margin-bottom:30px;font-size:20px;color:#0742b1;font-weight:bolder;text-align: center">歡迎注冊后臺管理系統</div><el-form-item style="margin-top: 20px;" prop="username"><el-input size="large" autocomplete="off" v-model="data.form.username" placeholder="請輸入賬號" prefix-icon="User" ></el-input></el-form-item><el-form-item prop="password"><el-input show-password="show-password" autocomplete="off" size="large" v-model="data.form.password" placeholder="請輸入密碼" prefix-icon="Lock"></el-input></el-form-item><el-form-item prop="confirmPassword"><el-input show-password="show-password" autocomplete="off" size="large" v-model="data.form.confirmPassword" placeholder="請再次輸入密碼" prefix-icon="Lock"></el-input>{{data.form.confirmPassword}}</el-form-item><div><el-button size="large" style="width: 48%" type="primary" @click="register()">注 冊</el-button><el-button size="large" style="width: 48%" type="info">取 消</el-button></div><div style="text-align: right;margin-top: 20px;">已有賬號?請<a style="color: #0742b1;text-decoration: none;" href="/login">登錄</a></div></el-form></div></div></div>
</template>
<script setup>
import { reactive,ref} from "vue";
import request from "@/utils/request.js";
import {ElMessage} from "element-plus";const res = ref()const validatePass = (rule, value, callback) => {if (!value) {callback(new Error('請再次輸入密碼'))} else if (value !== data.form.password) {callback(new Error("兩次輸入密碼不一致!"))} else {callback()}
}
const data = reactive({form:{username:'',password:'',confirmPassword:''},rules:{username:[{required:true,message:'請輸入賬號',trigger:'blur'}],password:[{required:true,message:'請輸入密碼',trigger:'blur'}],confirmPassword:[{validator:validatePass,trigger:'blur'}]}
})
const formRef = ref()
const register = () => {formRef.value.validate((valid) => {if (valid) {request.post('/register', data.form).then(res => {if (res.code === '200') {ElMessage.success('注冊成功');location.href = '/login'} else {ElMessage.error(res.msg); // 顯示業務錯誤消息}}).catch(error => {if (error.response) {// 處理 HTTP 錯誤狀態碼(如 400)const { data } = error.response;if (data && data.msg) {ElMessage.error(data.msg); // 顯示后端返回的錯誤消息} else {ElMessage.error('請求失敗,請稍后重試');}} else {ElMessage.error('網絡請求失敗,請檢查網絡連接');}});}});
}</script>
<!--scoped表示當頁生效-->
<style scoped>
.Register_container{height: 100vh;overflow:hidden;background-image: url("@/assets/login_bg.png");background-size:cover ;background-position: 0 -40px;
}
.Register_box{width: 50%;height: 100%;display: flex;align-items: center;right: 0;position: absolute;
}
</style>
3.添加兩個視圖的路由
下面是index.js的完整代碼
import { createRouter, createWebHistory } from 'vue-router'const router = createRouter({history: createWebHistory(import.meta.env.BASE_URL),routes: [{path: '/',redirect: '/login',},{path: '/button',name: 'button',component: () => import('../views/Button.vue'),},{path:'/manager',name:'manager',component:()=>import('../views/Manager.vue'),children:[{path:'/manager/employeeDataOp',name:'employeeDataOp',meta:{title:'員工數據操作'},component:()=>import('../views/employeeDataOp.vue')},{path:'/manager/home',name:'home',meta:{title:'首頁'},component:()=>import('../views/home.vue')},{path:'/manager/adminDataOp',name:'adminDataOp',meta:{title:'管理員數據操作'},component:()=>import('../views/adminDataOp.vue')}]},{path:'/login',name:'login',meta:{title:'登錄界面'},component:()=>import('../views/Login.vue')},{path:'/form',name:'form',component:()=>import('../views/form.vue')},{path:'/register',name:'register',meta:{title:'注冊界面'},component:()=>import('../views/Register.vue')},{path:'/404',name:'404',meta:{title:'404'},component:()=>import('../views/404.vue')},{path:'/:pathMatch(.*)*',redirect:'/404',}],
})
router.beforeEach((to,from,next)=>{document.title=to.meta.title;next()
})export default router
4.后端添加兩個功能的API接口
EmployeeController.java文件
@PostMapping("/login")public Result login(@RequestBody Employee employee){Employee findEmployee = employeeService.login(employee);return Result.success(findEmployee);}@PostMapping("/register")public Result register(@RequestBody Employee employee){Employee employee1 = employeeService.register(employee);return Result.success(employee1);}
5.為接口添加業務層方法
public Employee login(Employee employee) {Employee findEmployee = employeeMapper.selectByUsername(employee.getUsername());if (findEmployee == null){throw new ServiceException(ErrorCode.EMPLOYEE_NOT_FOUND);}if (!findEmployee.getPassword().equals(employee.getPassword())){throw new ServiceException(ErrorCode.EMPLOYEE_LOGIN_ERROR);}return findEmployee;}public Employee register(Employee employee){Employee findEmployee = employeeMapper.selectByUsername(employee.getUsername());employee.setRole("EMP");employee.setName("默認名稱");employee.setGender("男");employee.setTitle("普通員工");employee.setBirthday(new Date());if (findEmployee != null){throw new ServiceException(ErrorCode.EMPLOYEE_REGISTER_ERROR_USERNAME);}int row = employeeMapper.insert(employee);if(row!=1){throw new ServiceException(ErrorCode.EMPLOYEE_ADD_ERROR);}return employee;}
添加依賴
<dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.8.37</version></dependency>
對這里將原先的EmployeeServcieException.java改為ServcieException.java
然后ErrorCode加幾個常量下面是完整代碼
package com.cdp.zwy.zwy_manager_back_v1.common;/*** @description: 業務異常枚舉類* @author bug制作者* @date 2025/4/6 20:40* @version 1.0*/public enum ErrorCode {NOT_DATA("10000","沒有數據"),EMPLOYEE_NOT_FOUND("10001", "該員工不存在"),EMPLOYEE_ADD_ERROR("10002", "添加員工失敗"),EMPLOYEE_DELETE_ERROR("10003", "刪除員工失敗"),EMPLOYEE_MODIFY_ERROR("10004", "修改員工失敗"),EMPLOYEE_LOGIN_ERROR("10005", "登錄失敗"),EMPLOYEE_REGISTER_ERROR_USERNAME("10006","不能注冊,該用戶已經存在");private final String code;private final String msg;ErrorCode(String code, String msg) {this.code = code;this.msg = msg;}public String getCode() {return code;}public String getMsg() {return msg;}}
測試接口