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

宁波网站建设找哪家好企业营销策划推广

宁波网站建设找哪家好,企业营销策划推广,wordpress 高级版,上海东道设计先写前端再写后端 前提&#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/586354.html

相关文章:

  • 东莞网站推广设计网站建设合同性质
  • 有个人做网站的网站开发框架书籍
  • 互联网网站开发服务合同范本珠海知业科技
  • 南通做网站多少钱公司网站大全
  • 建设网站深圳海宁营销型网站设计
  • 泊头哪有哪家做网站做的号郑州网站权重
  • 厦门怎么没有 网站备案什么网站可以买世界杯
  • 网站推广主要用的软件深圳企业网站制作流程
  • 网站里的活动专题栏怎么做无限弹窗网站链接怎么做
  • 有网站源码怎么做网站全面的移动网站建设
  • 济南天桥区做网站公司wordpress忘记用户名密码破解
  • 广东专业移动网站服务商怎么找一手app推广代理
  • 建设银行手机登陆网站清远最新通知
  • 微信公众号链接的网站怎么做凡科怎么建设网站
  • 门户网站ui设计公司网站制作可以使用开源系统吗
  • 上市公司查询网站平台门户网站建设方案
  • 找人做网站应该注意什么设计公司官网梁志天
  • 做酒的网站有哪些国内ip地址代理免费
  • 知名商城网站建设多少钱长沙人才市场招聘信息
  • 网站域名保护几年wordpress重定向循环
  • 网站说服力网站开发项目教程任务分解
  • ae成品免费下载网站iis7如何设置ip做网站
  • 苏州营销型网站制作公司金棕榈客户关系管理系统
  • 安徽电子学会网站建设学网络营销
  • 在线做分析图的网站苏州网站推广建设
  • wordpress网站全过程如何建立公司官网
  • 网站无备案做视频解析网站播放器和接口
  • 网站域名是什成都网站开发环球中心
  • 织梦dedecms5.6 网站搬家详细教程如何做网站吸引广告商
  • 西安网站开发公司排名我的网站怎么做