基于javaweb的SpringBoot牙科诊所管理系统(java+springboot+mybatis+vue+elementui+mysql)

运行环境

Java≥8、MySQL≥5.7、Node.js≥14

开发工具

后端:eclipse/idea/myeclipse/sts等均可配置运行
前端:WebStorm/VSCode/HBuilderX等均可

❗没学过node.js的不要搞前后端分离项目

适用

课程设计,大作业,毕业设计,项目练习,学习演示等

功能说明

291524072608

301524072608

311524072608

321524072608

331524072608

341524072608

351524072608

361524072608

371524072608

基于javaweb的SpringBoot牙科诊所管理系统(java+springboot+mybatis+vue+elementui+mysql)

项目介绍

基于Springboot Vue牙科诊所管理系统

角色:管理员、医生、用户三种角色,分为前后台;

用户:用户在前台可以查看首页、公告、医生等信息;用户登录后,可进行医生预约、查看我的病例、预约记录等信息;

管理员:管理员登录成功后进入到系统操作界面,可以对个人中心、管理员管理、基础数据管理、公告管理、医生管理、医生预约管理、病例管理、用户管理、轮播图信息等功能模块进行相对应操作。

医生:医生登录成功后进入到系统操作界面,可以对个人中心、公告管理、医生预约管理、病例管理、用户管理等功能模块进行相应操作。

环境需要

1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。

2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA;

3.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS; 

4.数据库:MySql 5.7/8.0版本均可;

5.是否Maven项目:是;

技术栈

后端:SpringBoot+Mybaits

前端:Vue+ElementUI+Layui+HTML+CSS+JS

使用说明

项目运行:

  1. 使用Navicat或者其它工具,在mysql中创建对应sql文件名称的数据库,并导入项目的sql文件;

  2. 使用IDEA/Eclipse/MyEclipse导入项目,导入成功后请执行maven clean;maven install命令;

  3. 将项目中application.yml配置文件中的数据库配置改为自己的配置;

4.运行项目,在浏览器中输入地址:

前台地址:http://localhost:8080/yakezhensuo/front/index.html

用户:a1/123456

后台地址:http://localhost:8080/yakezhensuo/admin/dist/index.html#/login

管理员:admin/admin

医生:a3/123456

系统架构图:

首页展示:

医生信息展示:

公告页展示:

我的病例信息展示:

医生预约展示: 

后台病例管理:

公告类型管理:

公告管理:

 医生管理控制层:

@Controller

@RequestMapping(“doctor”)

public class DoctorController {

@Autowired

private DoctorService doctorService;

/*

  • 查询医生

  • */

@RequestMapping(“doctorList”)

@ResponseBody

public Object doctorList(Doctor doctor, Integer page, Integer limit){

PageHelper.startPage(page, limit);

List listAll = doctorService.doctorList(doctor);

PageInfo pageInfo = new PageInfo(listAll);

Map<String, Object> tableData = new HashMap<String, Object>();

//这是layui要求返回的json数据格式

tableData.put(“code”, 0);

tableData.put(“msg”, “”);

//将全部数据的条数作为count传给前台(一共多少条)

tableData.put(“count”, pageInfo.getTotal());

//将分页后的数据返回(每页要显示的数据)

tableData.put(“data”, pageInfo.getList());

return tableData;

/*

  • 添加医生

  • */

@RequestMapping(“addDoctor”)

@ResponseBody

public Object addDoctor(Doctor doctor, Paiban paiban){

int count = doctorService.count(doctor);

if(count==0){

int i = doctorService.addDoctor(doctor);

if(i==1){

return “添加成功”;

}else{

return “添加失败”;

}else{

return doctor.getDoctorName()+”已存在”;

/*

  • 修改医生

  • */

@RequestMapping(“editDoctor”)

@ResponseBody

public Object editDoctor(Doctor doctor){

int i = doctorService.editDoctor(doctor);

if(i==1){

return “修改成功”;

}else{

return “修改失败”;

/*

  • 删除医生

  • */

@RequestMapping(“deleteDoctor”)

@ResponseBody

public Object deleteDoctor(Integer doctorId){

int i1 = doctorService.checkCount(doctorId);

if(i1>0){

return “该医生还有病人”;

}else{

int i = doctorService.deleteDoctor(doctorId);

if(i==1){

return “删除成功”;

}else{

return “删除失败”;

/*

  • 查询科室

  • */

@RequestMapping(“findAllDepartments”)

@ResponseBody

public Object findAllDepartments(){

List allDepartments = doctorService.findAllDepartments();

return allDepartments;

/*

  • 查询类型

  • */

@RequestMapping(“findAllRegisteredtype”)

@ResponseBody

public Object findAllRegisteredtype(){

List allRegisteredtype = doctorService.findAllRegisteredtype();

return allRegisteredtype;

用户管理控制层:

@Controller

@RequestMapping(“user”)

public class UserController {

@Autowired

private UserService userService;

@RequestMapping(“selectAllUser”)

@ResponseBody

public Object selectAllUser(Integer page,Integer limit,User user){

PageHelper.startPage(page, limit);

List allUser = userService.selectAllUser(user);

PageInfo pageInfo = new PageInfo(allUser);

Map<String, Object> tableData = new HashMap<String, Object>();

//这是layui要求返回的json数据格式

tableData.put(“code”, 0);

tableData.put(“msg”, “”);

//将全部数据的条数作为count传给前台(一共多少条)

tableData.put(“count”, pageInfo.getTotal());

//将分页后的数据返回(每页要显示的数据)

tableData.put(“data”, pageInfo.getList());

return tableData;

/*

  • 修改用户

  • */

@RequestMapping(“updateUser”)

@ResponseBody

public Object updateUser(User user){

if(userService.updateUser(user)>0){

return “修改成功”;

}else{

return “修改失败”;

/*

  • 删除用户

  • */

@RequestMapping(“deleteUser”)

@ResponseBody

public Object deleteUser(Integer userid){

userService.deleteUser(userid);

return “删除成功”;

/*

  • 初始化用户分配角色

  • */

@RequestMapping(“initUserRole”)

@ResponseBody

public DataGridView initUserRole(Integer userid){

return userService.queryUserRole(userid);

/*

  • 添加用户

  • */

@RequestMapping(“addUser”)

@ResponseBody

public Object addUser(User user){

int i1 = userService.checkUser(user);

if(i1==1){

return “当前登陆名已存在”;

}else {

//加盐

String salt = UserCredentialsMatcher.generateSalt(6);

//MD5加密迭代两次

user.setPwd(UserCredentialsMatcher.encryptPassword(“md5”, “123456”, salt, 2));

user.setType(2);

user.setSalt(salt);

System.out.println(salt);

int i = userService.addUser(user);

if (i > 0) {

return “添加成功”;

} else {

return “添加失败”;

/*

  • 重置密码

  • */

@RequestMapping(“resetUserPwd”)

@ResponseBody

public Object resetUserPwd(User user,Integer userid){

user.setUserid(userid);

//加盐

String salt = UserCredentialsMatcher.generateSalt(6);

//MD5加密迭代两次

user.setPwd(UserCredentialsMatcher.encryptPassword(“md5”, “123456”, salt, 2));

user.setType(2);

user.setSalt(salt);

userService.resetUserPwd(user);

return “重置成功”;

/*

  • 保存用户和角色的关系

  • */

@RequestMapping(“saveUserRole”)

@ResponseBody

public Object saveUserRole(UserRole userRole){

userService.saveUserRole(userRole);

return “分配成功”;

} /*

  • 修改资料

  • */

@RequestMapping(“editLogin”)

@ResponseBody

public Object editLogin(User user){

int i = userService.editLogin(user);

if(i==1){

return “修改成功”;

}else{

return “修改失败”;

@Autowired

private MenuService menuService;

@RequestMapping(“editPwd”)

@ResponseBody

public Object editPwd(User user,String loginname,String pwd,String pwd1){

//第一步:建立subject

Subject subject = SecurityUtils.getSubject();

//第二步:封装token 凭证

UsernamePasswordToken token = new UsernamePasswordToken(loginname, pwd);

try {

//只要能通过认证就能通过了

subject.login(token);

//加盐

String salt = UserCredentialsMatcher.generateSalt(6);

//MD5加密迭代两次

user.setPwd(UserCredentialsMatcher.encryptPassword(“md5”, pwd1, salt, 2));

user.setSalt(salt);

userService.editPwd(user);

return “1”;//修改成功

} catch (IncorrectCredentialsException e) {

return “0”;//密码错误

系统管理控制层:

@Controller

public class SysController {

@Autowired

private UserService userService;

/*

  • 跳转管理菜单

  • */

@RequestMapping(“toMenuManager”)

public String toMenuManager() {

return “view/menu/menuManager”;

/*

  • 跳转加载菜单管理左边的菜单树

  • */

@RequestMapping(“toMenuLeft”)

public String toMenuLeft() {

return “view/menu/menuLeft”;

/*

  • 跳转加载菜单管理左边的增删改

  • */

@RequestMapping(“toMenuRight”)

public String toMenuRight() {

return “view/menu/menuRight”;

/*

  • 跳转加载角色

  • */

@RequestMapping(“toLoadAllRole”)

public String toLoadAllRole() {

return “view/role/roleManager”;

/*

  • 跳转加载用户

  • */

@RequestMapping(“toLoadAllUser”)

public String toLoadAllUser() {

return “view/user/userManager”;

/*

  • 跳转加载doctor.html

  • */

@RequestMapping(“toDoctor”)

public String toDoctor() {

return “view/center/doctor”;

/*

  • 跳转加载departments.html

  • */

@RequestMapping(“toDepartments”)

public String toDepartments() {

return “view/center/departments”;

/*

  • 跳转加载registeredtype.html

  • */

@RequestMapping(“toRegisteredType”)

public String toRegisteredtype() {

return “view/center/registeredType”;

/*

  • 跳转加载icon.html

  • */

@RequestMapping(“icon”)

public String icon() {

return “view/center/icon”;

/*

  • 跳转加载type.html

  • */

@RequestMapping(“toType”)

public String toType() {

return “view/center/type”;

/*

  • 跳转加载area.html

  • */

@RequestMapping(“toArea”)

public String toArea() {

return “view/center/area”;

/*

  • 跳转加载skull.html

  • */

@RequestMapping(“toSkull”)

public String toSkull() {

return “view/center/skull”;

/*

  • 跳转加载warehuose.html

  • */

@RequestMapping(“toWarehuose”)

public String toWarehuose() {

return “view/center/warehuose”;

/*

  • 跳转加载supplyManage.html

  • */

@RequestMapping(“toSupplyManage”)

public String toSupplyManage() {

return “view/center/supplyManage”;

/*

  • 跳转加载supply.html

  • */

@RequestMapping(“toSupply”)

public String toSupply() {

return “view/center/supply”;

/*

  • 跳转加载unit.html

  • */

@RequestMapping(“toUnit”)

public String toUnit() {

return “view/center/unit”;

/*

  • 跳转加载updateLogin.html

  • */

@RequestMapping(“toUpdateLogin”)

public String toUpdateLogin(User user, Integer userid, Model model) {

List users = userService.updateLogin(user);

model.addAttribute(“usersLogin”,users);

return “view/user/updateLogin”;

/*

  • 跳转加载projectTypeManage.html

  • */

@RequestMapping(“toProjectTypeManage”)

public String toProjectTypeManage() {

return “view/center/projectTypeManage”;

/*

  • 跳转加载paiban.html

  • */

@RequestMapping(“toPaiban”)

public String toPaiban() {

return “view/center/paiban”;

/*

  • 跳转加载drugdictionary.html

  • */

@RequestMapping(“toDrugdictionary”)

public String toDrugdictionary() {

return “view/center/drugdictionary”;

/*

  • 跳转加载main.html

  • */

@RequestMapping(“toMain”)

public String toMain() {

return “view/main/main”;

/*

  • 跳转加载reportManage.html

  • */

@RequestMapping(“toReportFinance”)

public String toReportFinance() {

return “view/finance/reportManage”;

/*

  • 跳转加载zhuYuanManage.html

  • */

@RequestMapping(“toZhuYaunManage”)

public String toZhuYaunManage() {

return “view/finance/zhuYuanManage”;

/*

  • 跳转加载zhuYuanManage.html

  • */

@RequestMapping(“toBingYear”)

public String toBingYear() {

return “view/finance/reportBing”;

/*

  • 跳转加载zhuYuanBing.html

  • */

@RequestMapping(“toBing2”)

public String toBing2() {

return “view/finance/zhuYuanBing”;

/*

  • 跳转加载doctorDuibi.html

  • */

@RequestMapping(“toDoctorDuibi”)

public String toDoctorDuibi() {

return “view/finance/doctorDuibi”;

/*

  • 跳转加载current.html

  • */

@RequestMapping(“toCurrent”)

public String toCurrenti() {

return “view/finance/current”;


项目链接:
https://javayms.github.io?id=251524522608201oz
https://javayms.pages.dev?id=251524522608201oz