Java项目:中药药方管理系统(java+SSM+JSP+bootstrap+Mysql)

本文主要是介绍Java项目:中药药方管理系统(java+SSM+JSP+bootstrap+Mysql),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

源码获取:俺的博客首页 "资源" 里下载!

项目介绍

本项目分为药房人员、管理员与医生三种角色;
药房人员角色包含以下功能:
药房人员登录,导诊单管理,采购管理等功能。

管理员角色包含以下功能:
管理员登录,药房人员管理,医生管理,药材信息管理,药方管理等功能。

医生角色包含以下功能:
医生登录,药材信息查询,药方查询,导诊单管理等功能。

环境需要

1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。
2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA;
3.tomcat环境:Tomcat 7.x,8.x,9.x版本均可
4.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS; 
5.数据库:MySql 5.7/8.0版本均可;
6.是否Maven项目:是;

技术栈

1. 后端:Spring+SpringMVC+Mbytes
2. 前端:JSP+css+javascript+bootstrap+jQuery

使用说明

1. 使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件;
2. 使用IDEA/Eclipse/MyEclipse导入项目,Eclipse/MyEclipse导入时,若为maven项目请选择maven;
若为maven项目,导入成功后请执行maven clean;maven install命令,然后运行;
3. 将项目中db.properties配置文件中的数据库配置改为自己的配置;
4. 运行项目,在浏览器中输入localhost:8080/ssm_yaofangsys/
医生账号/密码: doctor/123456
药房人员账号/密码:yaofang/123456
管理员账号/密码:admin/admin

 

 

 

 

 

 

 

登录管理控制层:

@Controller
@RequestMapping("/login")
public class LoginController extends BaseController{@Autowiredprivate ManageService manageService;@Autowiredprivate MedicineUserService medicineUserService;@Autowiredprivate DoctorService doctorService;/*** 跳转登陆* @return*/@RequestMapping("/login")public String login(){return "login/mLogin";}@RequestMapping("/index")public String index(){return "login/mIndex";}@RequestMapping("/uIndex")public String uIndex(Model model){return "login/uIndex";}@RequestMapping("/welcome")public String welcome(){return "login/welcome";}@RequestMapping("/mup")public String mpass(){return "login/mup";}/*** 管理员登陆* @param manage* @param request* @param response* @return*/@RequestMapping("/toLogin")public String toLogin(Manage manage,Integer role, HttpServletRequest request, HttpServletResponse response){if (role == null){return "redirect:/login/login.action";}//超级管理员if (role== 1){Manage byEntity = manageService.getByEntity(manage);if(byEntity != null){request.getSession().setAttribute("role", role);request.getSession().setAttribute("name", byEntity.getRealName());return "redirect:/login/index.action";}else{return "redirect:/login/login.action";}}//1 超级管理员2 医生  3 药房人员 if (role== 2){Doctor d = new Doctor();d.setPassword(manage.getPassword());d.setUserName(manage.getUserName());Doctor byEntity = doctorService.getByEntity(d);if(byEntity != null){request.getSession().setAttribute("role", role);request.getSession().setAttribute("name", byEntity.getRealName());request.getSession().setAttribute("userId", byEntity.getId());return "redirect:/login/index.action";}else{return "redirect:/login/login.action";}}//药房人员if (role== 3){MedicineUser d = new MedicineUser();d.setPassword(manage.getPassword());d.setUserName(manage.getUserName());MedicineUser byEntity = medicineUserService.getByEntity(d);if(byEntity != null){request.getSession().setAttribute("role", role);request.getSession().setAttribute("name", byEntity.getRealName());request.getSession().setAttribute("userId", byEntity.getId());return "redirect:/login/index.action";}else{return "redirect:/login/login.action";}}return null;}/*** 退出* @param request* @param response* @return*/@RequestMapping("/tuichu")public String tuichu( HttpServletRequest request, HttpServletResponse response){HttpSession session = request.getSession();session.invalidate();return "redirect:/login/login.action";}@RequestMapping("/uTui")public String uTui( HttpServletRequest request, HttpServletResponse response){HttpSession session = request.getSession();session.invalidate();return "redirect:/login/uLogin.action";}@RequestMapping("/head")private String head(){return "inc/head";}@RequestMapping("/left")private String left(){return "inc/left";}}

医生管理控制层: 

@Controller
@RequestMapping("/doctor")
public class DoctorController extends BaseController {/*** 依赖注入 start dao/service/===*/@Autowiredprivate DoctorService doctorService;@RequestMapping(value = "/findBySql")public String findBySql(Doctor doctor, Model model, HttpServletRequest request, HttpServletResponse response) {//分页查询String sql = "SELECT * FROM doctor WHERE 1=1  and isDelete = 0 ";//and isDelete = 0 if(!isEmpty(doctor.getUserName())){sql += " and userName like '%"+doctor.getUserName()+"%'";}if(!isEmpty(doctor.getPassword())){sql += " and password like '%"+doctor.getPassword()+"%'";}if(!isEmpty(doctor.getRealName())){sql += " and realName like '%"+doctor.getRealName()+"%'";}if(!isEmpty(doctor.getIdCard())){sql += " and idCard like '%"+doctor.getIdCard()+"%'";}if(!isEmpty(doctor.getPhone())){sql += " and phone like '%"+doctor.getPhone()+"%'";}if(!isEmpty(doctor.getSex())){sql += " and sex like '%"+doctor.getSex()+"%'";}if(!isEmpty(doctor.getIsDelete())){sql += " and isDelete like '%"+doctor.getIsDelete()+"%'";}sql += " ORDER BY ID DESC ";Pager<Doctor> pagers = doctorService.findBySqlRerturnEntity(sql);model.addAttribute("pagers", pagers);//存储查询条件model.addAttribute("obj", doctor);return "doctor/doctor";}/*** 跳至添加页面* @return*/@RequestMapping(value = "/add")public String add() {return "doctor/add";}/*** 添加执行* @return*/@RequestMapping(value = "/exAdd")public String exAdd(Doctor doctor, Model model, HttpServletRequest request, HttpServletResponse response) {doctor.setIsDelete(0);doctorService.insert(doctor);return "redirect:/doctor/findBySql";}/*** 跳至修改页面* @return*/@RequestMapping(value = "/update")public String update(Integer id,Model model) {Doctor obj = doctorService.load(id);model.addAttribute("obj",obj);return "doctor/update";}/*** 添加修改* @return*/@RequestMapping(value = "/exUpdate")public String exUpdate(Doctor doctor, Model model, HttpServletRequest request, HttpServletResponse response) {//1.通过实体类修改,可以多传修改条件doctorService.updateById(doctor);//2.通过主键id修改//doctorService.updateById(doctor);return "redirect:/doctor/findBySql";}/*** 删除通过主键* @return*/@RequestMapping(value = "/delete")public String delete(Integer id, Model model, HttpServletRequest request, HttpServletResponse response) {Doctor load = doctorService.load(id);load.setIsDelete(1);doctorService.update(load);doctorService.updateById(load);return "redirect:/doctor/findBySql";}}

药房人员管理控制层:

@Controller
@RequestMapping("/medicineUser")
public class MedicineUserController extends BaseController {/*** 依赖注入 start dao/service/===*/@Autowiredprivate MedicineUserService medicineUserService;@RequestMapping(value = "/findBySql")public String findBySql(MedicineUser medicineUser, Model model, HttpServletRequest request, HttpServletResponse response) {//分页查询String sql = "SELECT * FROM medicine_user WHERE 1=1  and isDelete = 0  ";//and isDelete = 0 if(!isEmpty(medicineUser.getUserName())){sql += " and userName like '%"+medicineUser.getUserName()+"%'";}if(!isEmpty(medicineUser.getPassword())){sql += " and password like '%"+medicineUser.getPassword()+"%'";}if(!isEmpty(medicineUser.getRealName())){sql += " and realName like '%"+medicineUser.getRealName()+"%'";}if(!isEmpty(medicineUser.getIdCard())){sql += " and idCard like '%"+medicineUser.getIdCard()+"%'";}if(!isEmpty(medicineUser.getPhone())){sql += " and phone like '%"+medicineUser.getPhone()+"%'";}if(!isEmpty(medicineUser.getSex())){sql += " and sex like '%"+medicineUser.getSex()+"%'";}if(!isEmpty(medicineUser.getIsDelete())){sql += " and isDelete like '%"+medicineUser.getIsDelete()+"%'";}sql += " ORDER BY ID DESC ";Pager<MedicineUser> pagers = medicineUserService.findBySqlRerturnEntity(sql);model.addAttribute("pagers", pagers);//存储查询条件model.addAttribute("obj", medicineUser);return "medicineUser/medicineUser";}/*** 跳至添加页面* @return*/@RequestMapping(value = "/add")public String add() {return "medicineUser/add";}/*** 添加执行* @return*/@RequestMapping(value = "/exAdd")public String exAdd(MedicineUser medicineUser, Model model, HttpServletRequest request, HttpServletResponse response) {medicineUser.setIsDelete(0);medicineUserService.insert(medicineUser);return "redirect:/medicineUser/findBySql";}/*** 跳至修改页面* @return*/@RequestMapping(value = "/update")public String update(Integer id,Model model) {MedicineUser obj = medicineUserService.load(id);model.addAttribute("obj",obj);return "medicineUser/update";}/*** 添加修改* @return*/@RequestMapping(value = "/exUpdate")public String exUpdate(MedicineUser medicineUser, Model model, HttpServletRequest request, HttpServletResponse response) {//1.通过实体类修改,可以多传修改条件medicineUserService.updateById(medicineUser);//2.通过主键id修改//medicineUserService.updateById(medicineUser);return "redirect:/medicineUser/findBySql";}/*** 删除通过主键* @return*/@RequestMapping(value = "/delete")public String delete(Integer id, Model model, HttpServletRequest request, HttpServletResponse response) {MedicineUser load = medicineUserService.load(id);load.setIsDelete(1);medicineUserService.updateById(load);return "redirect:/medicineUser/findBySql";}}

源码获取:俺的博客首页 "资源" 里下载!

这篇关于Java项目:中药药方管理系统(java+SSM+JSP+bootstrap+Mysql)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/408308

相关文章

Java NoClassDefFoundError运行时错误分析解决

《JavaNoClassDefFoundError运行时错误分析解决》在Java开发中,NoClassDefFoundError是一种常见的运行时错误,它通常表明Java虚拟机在尝试加载一个类时未能... 目录前言一、问题分析二、报错原因三、解决思路检查类路径配置检查依赖库检查类文件调试类加载器问题四、常见

Java注解之超越Javadoc的元数据利器详解

《Java注解之超越Javadoc的元数据利器详解》本文将深入探讨Java注解的定义、类型、内置注解、自定义注解、保留策略、实际应用场景及最佳实践,无论是初学者还是资深开发者,都能通过本文了解如何利用... 目录什么是注解?注解的类型内置注编程解自定义注解注解的保留策略实际用例最佳实践总结在 Java 编程

MySQL数据库约束深入详解

《MySQL数据库约束深入详解》:本文主要介绍MySQL数据库约束,在MySQL数据库中,约束是用来限制进入表中的数据类型的一种技术,通过使用约束,可以确保数据的准确性、完整性和可靠性,需要的朋友... 目录一、数据库约束的概念二、约束类型三、NOT NULL 非空约束四、DEFAULT 默认值约束五、UN

MySQL 多表连接操作方法(INNER JOIN、LEFT JOIN、RIGHT JOIN、FULL OUTER JOIN)

《MySQL多表连接操作方法(INNERJOIN、LEFTJOIN、RIGHTJOIN、FULLOUTERJOIN)》多表连接是一种将两个或多个表中的数据组合在一起的SQL操作,通过连接,... 目录一、 什么是多表连接?二、 mysql 支持的连接类型三、 多表连接的语法四、实战示例 数据准备五、连接的性

MySQL中的分组和多表连接详解

《MySQL中的分组和多表连接详解》:本文主要介绍MySQL中的分组和多表连接的相关操作,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录mysql中的分组和多表连接一、MySQL的分组(group javascriptby )二、多表连接(表连接会产生大量的数据垃圾)MySQL中的

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.