当前位置: 首页 > wzjs >正文

平面设计官方网站知名网站排名

平面设计官方网站,知名网站排名,珠海东莞网站建设,怒江北京网站建设先写前端再写后端 前提&#xff1a;ideavue3mybatisspringBoot3前后端分离实现对一张表的增删改查&#xff08;完整代码版&#xff09;-CSDN博客 项目地址 1.添加一个Login.vue视图 <template><div class"login_container"><div class"login…

先写前端再写后端

前提: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;}}

测试接口

http://www.dtcms.com/wzjs/102809.html

相关文章:

  • 广元企业网站建设美国搜索引擎排名
  • 做网站是干什么用的2019网站seo
  • 网站建设技术公司企业网站制作费用
  • 富锦建设局网站排名首页服务热线
  • 广广东网站建设seo首页网站
  • 做网站需要的资质站长工具视频
  • 影视自助建站官网人民网今日头条
  • 上杭县城乡规划建设局网站如何创建网站站点
  • 珠海移动网站设计上海还能推seo吗
  • 建设通相似网站北京全网推广
  • wordpress中触发鼠标按钮事件动态动态代码代码百度搜索名字排名优化
  • 建立网站分为几阶段市场营销方案怎么做
  • wordpress 仿值得买seo岗位工作内容
  • 外贸建立网站怎么做推广网站免费
  • 网站建设类行业资讯如何做好网络营销工作
  • 广州做外贸网站公司岳阳网站建设推广
  • 如何查网站的外链seo推广招聘
  • 网站建设制作要学什么北京做网站的公司有哪些
  • 做网站后端需要掌握什么技术抖音代运营收费详细价格
  • 凯里做网站it培训学校
  • WordPress图片生成文章图片优化软件
  • 评论回复网站怎么做的百度指数查询官网大数据
  • 网站建设背景及目的公司运营策划方案
  • 专门做广东11选5的网站电脑优化大师哪个好
  • 全国建设项目竣工验收公示网站谷歌浏览器下载app
  • 家在深圳歌词网站如何优化流程
  • 企业网站建设专业性体现在山东关键词快速排名
  • 温州哪里做网站游戏推广赚佣金的平台
  • 做网站+利润廊坊百度关键词排名平台
  • 做的比较好的海鲜网站网络营销有本科吗