——————————DescriptionStart——————————
运行环境
Java≥8、MySQL≥5.7、Node.js≥14
开发工具
后端:eclipse/idea/myeclipse/sts等均可配置运行
前端:WebStorm/VSCode/HBuilderX等均可
❗没学过node.js的不要搞前后端分离项目
适用
课程设计,大作业,毕业设计,项目练习,学习演示等
功能说明








基于javaweb的SpringBoot医院挂号系统(java+springboot+Maven+vue+elementui+layui+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
前端:layui+Vue+ELementUI
使用说明
项目运行: 1. 使用Navicat或者其它工具,在mysql中创建对应sql文件名称的数据库,并导入项目的sql文件; 2. 使用IDEA/Eclipse/MyEclipse导入项目,导入成功后请执行maven clean;maven install命令,然后运行; 3. 将项目中application.yml配置文件中的数据库配置改为自己的配置; 4. 运行项目,控制台提示运行成功后再去运行前端项目; 5. 管理员用户名密码:admin/admin 普通用户名密码:user/123456
文档介绍(系统功能模块设计、整体功能模块设计、用户模块设计、评论管理模块设计、数据库设计、数据库概念结构设计、数据库逻辑结构设计、医疗管理系统详细设计与实现、用户功能模块、前台首页界面、患者登录界面、患者注册界面、我的账户界面、医生详情界面、医院咨询界面、管理员功能模块、用户管理界面、留言管理界面、站点管理界面):
药品信息列表(公告消息、医院咨询、医生信息、药品信息):
医院咨询详情介绍(公告消息、医院咨询、医生信息、药品信息):
后台管理登录页面:
后台管理列表(站点管理、用户管理、管理员、患者、医生、内容管理、更多管理、医生信息、科室管理、挂号预约、就诊单、住院办理、药品信息、住院通知、药品类别、退费信息、检查信息)
——————————CodeStart——————————
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43
| public class BaseService <E>{
@Autowired @PersistenceContext private EntityManager entityManager;
Class<E> eClass = (Class<E>)((ParameterizedType)getClass().getGenericSuperclass()).getActualTypeArguments()[0];
private final String table = humpToLine(eClass.getSimpleName());
public Query runEntitySql(String sql){ return entityManager.createNativeQuery(sql, eClass); }
public Query runCountSql(String sql){ return entityManager.createNativeQuery(sql); }
public void insert(Map<String,Object> body){ StringBuffer sql = new StringBuffer("INSERT INTO "); sql.append("`").append(table).append("`").append(" ("); for (Map.Entry<String,Object> entry:body.entrySet()){ sql.append("`"+humpToLine(entry.getKey())+"`").append(","); } sql.deleteCharAt(sql.length()-1); sql.append(") VALUES ("); for (Map.Entry<String,Object> entry:body.entrySet()){ Object value = entry.getValue(); if (value instanceof String){ sql.append("'").append(entry.getValue()).append("'").append(","); }else { sql.append(entry.getValue()).append(","); } } sql.deleteCharAt(sql.length() - 1); sql.append(")"); log.info("[{}] - 插入操作:{}",table,sql); Query query = runCountSql(sql.toString()); query.executeUpdate(); }
@Transactional public void update(Map<String,String> query,Map<String,String> config,Map<String,Object> body){
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42
| public Map<String, Object> add(HttpServletRequest request) throws IOException { Map<String,Object> paramMap = service.readBody(request.getReader()); this.addMap(paramMap); return success(1); }
}
@RestController @RequestMapping("article_type") public class ArticleTypeController extends BaseController<ArticleType, ArticleTypeService> {
@Autowired public ArticleTypeController(ArticleTypeService service) { setService(service); }
}
@RestController @RequestMapping("user_group") public class UserGroupController extends BaseController<UserGroup, UserGroupService> {
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
|
@RestController @RequestMapping("/drug_information") public class DrugInformationController extends BaseController<DrugInformation,DrugInformationService> {
@Autowired public DrugInformationController(DrugInformationService service) { setService(service); }
@PostMapping("/add") @Transactional public Map<String, Object> add(HttpServletRequest request) throws IOException { Map<String,Object> paramMap = service.readBody(request.getReader()); this.addMap(paramMap); return success(1); }
}
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
| }
public Map<String,String> readConfig(HttpServletRequest request){ Map<String,String> map = new HashMap<>(); map.put(FindConfig.PAGE,request.getParameter(FindConfig.PAGE)); map.put(FindConfig.SIZE,request.getParameter(FindConfig.SIZE)); map.put(FindConfig.LIKE,request.getParameter(FindConfig.LIKE)); map.put(FindConfig.ORDER_BY,request.getParameter(FindConfig.ORDER_BY)); map.put(FindConfig.FIELD,request.getParameter(FindConfig.FIELD)); map.put(FindConfig.GROUP_BY,request.getParameter(FindConfig.GROUP_BY)); map.put(FindConfig.MAX_,request.getParameter(FindConfig.MAX_)); map.put(FindConfig.MIN_,request.getParameter(FindConfig.MIN_)); return map; }
public void importDb(MultipartFile file) throws IOException { if (file.isEmpty()) { return; } List<Map<String,String>> body = new ArrayList<>(); String fileName = file.getOriginalFilename(); if (fileName == null){ return; } String suffix = fileName.substring(fileName.lastIndexOf(".")+1); InputStream ins = file.getInputStream(); Workbook wb = null; if(suffix.equals("xlsx")){ wb = new XSSFWorkbook(ins); }else{ wb = new HSSFWorkbook(ins); } Sheet sheet = wb.getSheetAt(0); if(null != sheet){ for(int line = 0; line <= sheet.getLastRowNum();line++){ Row row = sheet.getRow(line); if(null == row){ continue; } Iterator<Cell> cellIterator = row.cellIterator(); StringBuffer sql = new StringBuffer("INSERT INTO ").append(table).append(" VALUES (null,"); while (cellIterator.hasNext()){ sql.append(cellIterator.next().getStringCellValue()).append(","); } sql.deleteCharAt(sql.length()); sql.append(")"); runCountSql(sql.toString()); } } }
public HSSFWorkbook exportDb(Map<String,String> query,Map<String,String> config){ Query select = select(query, config);
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
| sql.append(" "); return sql.toString(); } catch (UnsupportedEncodingException e) { log.info("拼接sql 失败:{}", e.getMessage()); } } return ""; }
public Map<String,Object> readBody(BufferedReader reader){ BufferedReader br = null; StringBuilder sb = new StringBuilder(""); try{ br = reader; String str; while ((str = br.readLine()) != null){ sb.append(str); } br.close(); String json = sb.toString(); return JSONObject.parseObject(json, Map.class); }catch (IOException e){ e.printStackTrace(); }finally{ if (null != br){ try{ br.close(); }catch (IOException e){ e.printStackTrace(); } } } return null; }
public Map<String,String> readQuery(HttpServletRequest request){ String queryString = request.getQueryString(); if (queryString != null && !"".equals(queryString)) { String[] querys = queryString.split("&"); Map<String, String> map = new HashMap<>(); for (String query : querys) { String[] q = query.split("="); map.put(q[0], q[1]); } map.remove(FindConfig.PAGE); map.remove(FindConfig.SIZE); map.remove(FindConfig.LIKE); map.remove(FindConfig.ORDER_BY); map.remove(FindConfig.FIELD); map.remove(FindConfig.GROUP_BY); map.remove(FindConfig.MAX_); map.remove(FindConfig.MIN_); return map; }else {
|
——————————PayStart——————————
项目链接:
https://javayms.github.io?id=461524170701201gx
https://javayms.pages.dev?id=461524170701201gx