免费分享一套SpringBoot+Vue实验室(预约)管理系统,帅呆了~~

大家好,我是java1234_小锋老师,看到一个不错的SpringBoot+Vue实验室(预约)管理系统 ,分享下哈。

项目视频演示

【免费】SpringBoot+Vue实验室(预约)管理系统 Java毕业设计_哔哩哔哩_bilibili【免费】SpringBoot+Vue实验室(预约)管理系统 Java毕业设计项目来自互联网,免费开源分享,严禁商业。更多毕业设源码:http://www.java1234.com/a/bysj/javaweb/, 视频播放量 161、弹幕量 0、点赞数 3、投硬币枚数 2、收藏人数 4、转发人数 1, 视频作者 java1234官方, 作者简介 公众号:java1234 微信:java9266,相关视频:【免费】javaweb实验室管理系统毕业设计,【免费】javaweb大学生就业管理系统毕业设计,【免费】javaweb超市管理系统高级版毕业设计,【免费】SpringBoot+Vue药店(药房)管理系统 Java毕业设计,【免费】javaweb企业人事管理系统毕业设计,【免费】javaweb物业管理系统毕业设计,【免费】javaweb员工工资管理系统毕业设计,【免费】javaweb超市管理系统毕业设计,【免费】基于springboot的进销存(仓库)管理系统 Java毕业设计,【免费】javaweb高校教务管理系统毕业设计icon-default.png?t=N7T8https://www.bilibili.com/video/BV14S421N7GL/

项目介绍

国家对高校实验教学的重视程度不断提高,正在不断的探索高校教学改革的方法。其中,建设教学示范中心是推动高校教学发展的方法之一。高校教学示范中心是组织高水平教学,培养创新型、应用型人才的重要基地;是提高教学质量,整合、共享教学资源,深化实验教学改革的重要途径。我校紧跟时代发展的步伐,申请并成立了多个教学示范中心。此前,我校计算机科学与技术实验教学示范中心在信息化建设方面投入的精力较少,信息化管理程度不足。为加强教学示范中心信息化建设,本人选择信息化管理中预约管理方向进行探究,设计一款实验室预约管理系统,来填补教学示范中心在实验室预约管理方向的空缺,推动本校教学示范中心的发展。

按照预期要求,本预约管理系统可以实现对实验室预约的网络化、信息化管理,能够将学生和教师从繁琐的过程中解放出来。学生可以随时随地查看实验室信息,按自己需求预约。管理人员可以通过网络审批,大幅度加快了审核的速度,减少了管理人员的工作量,提高了实验室资源的利用率。因此在教学方面,本课题是有实践意义的

系统展示

部分代码

package com.li.lrms.controller;import com.alibaba.excel.util.StringUtils;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.li.lrms.common.result.Result;
import com.li.lrms.model.user.User;
import com.li.lrms.service.UserService;
import com.li.lrms.util.JwtUtils;
import com.li.lrms.util.MD5;
import com.li.lrms.vo.login.EditVo;
import com.li.lrms.vo.user.UserQueryVo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;import javax.servlet.http.HttpServletRequest;
import java.util.List;@CrossOrigin
@RestController
@RequestMapping("/admin/users/user")
public class UserController {@Autowiredprivate UserService userService;//1.查询所有用户@GetMapping("findAll")public Result findAllUser() {List<User> list = userService.list();return Result.ok(list);}//2.增加@PostMapping("addUser")public Result addUser(@RequestBody User users) {//        String password = users.getPassword();String encrypt = MD5.encrypt("123456");users.setPassword(encrypt);boolean b = userService.save(users);if (b) return Result.ok();else return Result.fail();}//3.删除@DeleteMapping("{id}")public Result removeUser(@PathVariable String id) {boolean b = userService.removeById(id);if (b) return Result.ok();else return Result.fail();}//4.条件查询分页/*** 1.创建vo类,封装条件值* 2.编写controller* 获取当前页面current和每页对象值limit* 获取条件语句 hospitalSetQueryVo*/@PostMapping("findpage/{current}/{limit}")public Result findPageUser(@PathVariable long current, @PathVariable long limit,@RequestBody(required = false) UserQueryVo usersQueryVo) {//创建page对象,传递当前页,每页记录数Page<User> page = new Page<>(current, limit);//构建查询条件QueryWrapper<User> queryWrapper = new QueryWrapper<>();String name = usersQueryVo.getUserName();String role = usersQueryVo.getRole();if (!StringUtils.isEmpty(role)) {     //输入非空queryWrapper.eq("role", role);  //获取用户id}if (!StringUtils.isEmpty(name)) {queryWrapper.like("user_name", usersQueryVo.getUserName()); //获取用户id}//调用方法实现分页查询IPage<User> usersPage = userService.page(page, queryWrapper);//返回结果return Result.ok(usersPage);}//按id查询@GetMapping("getUsers/{id}")public Result getUsers(@PathVariable String id) {User users = userService.getById(id);return Result.ok(users);}//修改用户信息@PostMapping("updateUsers")public Result updateUsers(@RequestBody User users) {String password = users.getPassword();String encrypt = MD5.encrypt(password);users.setPassword(encrypt);boolean update = userService.updateById(users);if (update) return Result.ok();else return Result.fail();}//批量删除@DeleteMapping("batchRemove")public Result batchRemoveUsers(@RequestBody List<String> list) {userService.removeByIds(list);return Result.ok();}//修改状态@PutMapping("updateStatus/{id}/{status}")public Result setStatus(@PathVariable String id, @PathVariable Integer status) {//根据id查询User users = userService.getById(id);//修改信息users.setStatus(status);//调用函数更新userService.updateById(users);return Result.ok();}//4.修改个人信息//1.电话号码 2.密码  3.邮箱  4.@PostMapping("editInfo")public Result editInfo(@RequestBody(required = false) EditVo editVo, HttpServletRequest request) {String userId = JwtUtils.getMemberIdByJwtToken(request);User user = userService.getByUserId(userId);   //获得该用户信息userService.updateInfo(editVo, user);return Result.ok();}}
<template><div class="login-container"><el-form ref="loginForm" :model="loginForm" :rules="loginRules" class="login-form" auto-complete="on"label-position="left"><div class="title-container"><h3 class="title">实验室信息管理系统</h3></div><el-form-item prop="username"><span class="svg-container"><svg-icon icon-class="user"/></span><el-inputref="username"v-model="loginForm.username"placeholder="Username"name="username"type="text"tabindex="1"auto-complete="on"/></el-form-item><el-form-item prop="password"><span class="svg-container"><svg-icon icon-class="password"/></span><el-input:key="passwordType"ref="password"v-model="loginForm.password":type="passwordType"placeholder="Password"name="password"tabindex="2"auto-complete="on"@keyup.enter.native="handleLogin"/><span class="show-pwd" @click="showPwd"><svg-icon :icon-class="passwordType === 'password' ? 'eye' : 'eye-open'"/></span></el-form-item><el-button :loading="loading" type="primary" style="width:48%;margin-bottom:30px;"@click.native.prevent="handleLogin">登录</el-button><el-button type="primary" style="width:48%;margin-bottom:30px;" @click="dialogFormVisible = true">注册</el-button><div style="text-align: center"><el-radio v-model="loginForm.role" label="user">学生  </el-radio><el-radio v-model="loginForm.role" label="teacher">教师   </el-radio><el-radio v-model="loginForm.role" label="admin">管理员    </el-radio></div><el-dialog title="" :visible.sync="dialogFormVisible"><div class="register"><h1>注册</h1><el-form ref="registerForm" :model="user" label-width="100px"><el-form-item label="姓名"><el-input v-model="user.userName" placeholder="Enter your username"></el-input></el-form-item><el-form-item label="账号"><el-input v-model="user.userId" placeholder="Enter your username"></el-input></el-form-item><el-form-item label="密码"><el-input v-model="user.password" type="password" placeholder="Enter your password"></el-input></el-form-item><el-form-item label="电话"><el-input v-model="user.phone" placeholder="Enter your phone number"></el-input></el-form-item><el-form-item label="邮箱"><el-input v-model="user.email" placeholder="Enter your email"></el-input></el-form-item><el-form-item><el-button type="primary" @click="register()">注册</el-button><el-button @click="dialogFormVisible = false">返回</el-button></el-form-item></el-form></div></el-dialog><div class="tips"><span style="margin-right:20px;"></span><span> </span></div></el-form><div align="center"><a href="http://www.java1234.com/a/bysj/javaweb/" target="_blank"><font color="red">Java1234收藏整理</font></a></div></div>
</template><script>
import {validUsername} from '@/utils/validate'
import axios from "axios";export default {name: 'Login',data() {const validateUsername = (rule, value, callback) => {if (!validUsername(value)) {callback(new Error('请输入正确的用户名'))} else {callback()}}const validatePassword = (rule, value, callback) => {if (value.length < 6) {callback(new Error('密码不小于6位'))} else {callback()}}return {user: {userName: '',userId: '',password: '',phone: '',email: '',role: 'user'},dialogFormVisible: false,loginForm: {username: '20171506001',password: '123456',role: ''},loginRules: {username: [{required: true, trigger: 'blur', validator: validateUsername}],password: [{required: true, trigger: 'blur', validator: validatePassword}]},loading: false,passwordType: 'password',redirect: undefined}},watch: {$route: {handler: function (route) {this.redirect = route.query && route.query.redirect},immediate: true}},methods: {register() {this.$refs.registerForm.validate(valid => {if (valid) {axios.post('http://localhost:8200/admin/member/stuRegister', this.user).then(response => {console.log(response.data);this.$message.success('注册成功')// handle response}).catch(error => {console.log(error);// handle error});} else {console.log('Validation failed');}});},resetForm() {this.$refs.registerForm.resetFields();},showPwd() {if (this.passwordType === 'password') {this.passwordType = ''} else {this.passwordType = 'password'}this.$nextTick(() => {this.$refs.password.focus()})},handleLogin() {this.$refs.loginForm.validate(valid => {if (valid) {this.loading = truethis.$store.dispatch('user/login', this.loginForm).then(() => {this.$router.push({path: this.redirect || '/'})this.loading = false}).catch(() => {this.loading = falsethis.$message({type: "error",message: "用户名或密码输入有误!",})})} else {console.log('error submit!!')return false}})},}
}
</script><style lang="scss">
/* 修复input 背景不协调 和光标变色 */
/* Detail see https://github.com/PanJiaChen/vue-element-admin/pull/927 */$bg: #283443;
$light_gray: #232222;
$cursor: #fff;@supports (-webkit-mask: none) and (not (cater-color: $cursor)) {.login-container .el-input input {color: $cursor;}
}/* reset element-ui css */
.login-container {.el-input {display: inline-block;height: 47px;width: 85%;input {background: transparent;border: 0px;-webkit-appearance: none;border-radius: 0px;padding: 12px 5px 12px 15px;color: $light_gray;height: 47px;caret-color: $cursor;&:-webkit-autofill {box-shadow: 0 0 0px 1000px $bg inset !important;-webkit-text-fill-color: $cursor !important;}}}.el-form-item {border: 1px solid rgba(255, 255, 255, 0.1);background: rgba(0, 0, 0, 0.1);border-radius: 5px;color: #454545;}
}
</style><style lang="scss" scoped>
.register {width: 500px;margin: 0 auto;padding: 50px 0;
}$bg: #2d3a4b;
$dark_gray: #889aa4;
$light_gray: #eee;.login-container {min-height: 100%;width: 100%;background-color: $bg;overflow: hidden;.login-form {position: relative;width: 520px;max-width: 100%;padding: 160px 35px 0;margin: 0 auto;overflow: hidden;}.tips {font-size: 14px;color: #fff;margin-bottom: 10px;span {&:first-of-type {margin-right: 16px;}}}.svg-container {padding: 6px 5px 6px 15px;color: $dark_gray;vertical-align: middle;width: 30px;display: inline-block;}.title-container {position: relative;.title {font-size: 26px;color: $light_gray;margin: 0px auto 40px auto;text-align: center;font-weight: bold;}}.show-pwd {position: absolute;right: 10px;top: 7px;font-size: 16px;color: $dark_gray;cursor: pointer;user-select: none;}
}
</style>

源码下载

CSDN 1积分下载:https://download.csdn.net/download/caofeng891102/88865898

或者免费领取加小锋老师wx:java9266

热门推荐

免费分享一套SpringBoot+Vue药店(药房)管理系统,帅呆了~~-CSDN博客

免费分享一套微信小程序扫码点餐(订餐)系统(uni-app+SpringBoot后端+Vue管理端技术实现) ,帅呆了~~_微信小程序扫码点餐 java vue-CSDN博客

免费分享一套微信小程序外卖跑腿点餐(订餐)系统(uni-app+SpringBoot后端+Vue管理端技术实现) ,帅呆了~~_跑腿或点餐的uniapp前端模版-CSDN博客

免费分享一套Springboot+Vue前后端分离的在线教育平台系统,挺漂亮的-CSDN博客

免费分享一套Springboot+Vue前后端分离的停车场管理系统,挺漂亮的-CSDN博客

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/491904.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spring事务模板及afterCommit存在的坑

大家好&#xff0c;我是墨哥&#xff08;隐墨星辰&#xff09;。今天的内容来源于两个线上问题&#xff0c;主要和大家聊聊为什么支付系统中基本只使用事务模板方法&#xff0c;而不使用声明式事务Transaction注解&#xff0c;以及使用afterCommit()出现连接未按预期释放导致的…

云尚办公-0.3.0

5. controller层 import pers.beiluo.yunshangoffice.model.system.SysRole; import pers.beiluo.yunshangoffice.service.SysRoleService;import java.util.List;//RestController&#xff1a;1.该类是控制器&#xff1b;2.方法返回值会被写进响应报文的报文体&#xff0c;而…

matlab新能源汽车三自由度操纵稳定性分析及优化

1、内容简介 略 可以交流、咨询、答疑 55-新能源汽车三自由度操纵稳定性分析及优化 2、内容说明 略 摘 要 电动化是节能减排、寻求替代能源的最佳途径&#xff0c;已成为行业共识&#xff0c;论文基于江西科技学院桑塔纳轿车油改气项目&#xff0c;在拆除发动机、变速…

大数据可视化的设计规范,全面剖析,很实用。

大数据可视化的设计规范需要考虑到数据量大、复杂度高、数据类型多样等特点。以下是一份常见的大数据可视化设计规范&#xff0c;供您参考&#xff1a; 设计原则 简单易用&#xff1a;保证用户操作简单、直观&#xff0c;降低用户认知负担。数据准确&#xff1a;保证数据准确…

【LeetCode周赛】第 386 场周赛

目录 3046. 分割数组 简单3047. 求交集区域内的最大正方形面积 中等3048. 标记所有下标的最早秒数 I 中等 3046. 分割数组 简单 3046. 分割数组 分析&#xff1a; 查看数组内有没有重复超过2次的数即可。 代码&#xff1a; class Solution { public:bool isPossibleToSplit…

数据结构:链表的冒泡排序

法一&#xff1a;修改指针指向 //法二 void maopao_link(link_p H){if(HNULL){printf("头节点为空\n");return;}if(link_empty(H)){printf("链表为空\n");return;}link_p tailNULL;while(H->next->next!tail){link_p pH;link_p qH->next;while(q…

FPGA 与 数字电路的关系 - 这篇文章 将 持续 更新 :)

先说几个逻辑&#xff1a;&#xff08;强调一下在这篇文章 输入路数 只有 1个或2个&#xff0c;输出只有1个&#xff0c;N个输入M个输出以后再说&#xff09; 看下面的几个图&#xff1a; 图一&#xff08; 忘了 这是 啥门&#xff0c;不是门吧 &#xff1a;&#xff09;也就…

电商赠品数据可以监测吗

很多店铺为了引流&#xff0c;会在标题、图片上标明促销活动&#xff0c;常见的有赠品描述&#xff0c;由于现在监测价格技术的壁垒&#xff0c;其实很多时候&#xff0c;主图上的赠品信息因其描述方式、字体等的不同&#xff0c;会导致监测不出来的情况出现&#xff0c;这也给…

【数据库】MySQL视图 | 用户管理

文章目录 1 :peach:视图:peach:1.1 :apple:基本使用:apple:1.1.1 :lemon:创建视图:lemon:1.1.2 :lemon:案例:lemon:1.1.3 :lemon:删除视图:lemon: 1.2 :apple:视图规则和限制:apple: 2 :peach:用户管理:peach:2.1 :apple:用户信息:apple:2.2 :apple:创建用户:apple:2.3 :apple:…

SocketWeb实现小小聊天室

SocketWeb实现小小聊天室 消息推送的常见方式轮询长轮询SSE&#xff08;server-sent event&#xff09;&#xff1a;服务器发送事件WebSocketWebSocket简介WebSocket API 实现小小聊天室实现流程消息格式客户端-->服务端服务端-->客户端 消息推送的常见方式 轮询 浏览器…

皓学IT:WEB05-Servlet

一、Servlet 1.1.概述 Servlet是SUN公司提供的一套规范&#xff0c;名称就叫Servlet规范&#xff0c;它也是JavaEE规范之一。我们可以像学习Java基础一样&#xff0c;通过API来学习Servlet。这里需要注意的是&#xff0c;在我们之前JDK的API中是没有Servlet规范的相关内容&am…

“智能语音指令解析“ 基于NLP与语音识别的关键工单信息提取,

"智能语音指令解析" 基于NLP与语音识别的关键工单信息提取&#xff0c; 1. 背景介绍1.1 场景痛点1.2 方案选型 2. 准备开发环境3. PaddleSpeech 语音识别快速使用4. PaddleNLP 信息抽取快速使用5. 语音工单信息抽取核心功能实现6. 语音工单信息抽取网页应用6.1 网页前…