Java-基于SSM的药品销售管理系统
项目背景
本论文主要论述了如何使用JAVA语言开发一个药品销售系统 ,本系统将严格按照软件开发流程进行各个阶段的工作,采用B/S架构,面向对象编程思想进行项目开发。在引言中,作者将论述药品销售系统的当前背景以及系统开发的目的,后续章节将严格按照软件开发流程,对系统进行各个阶段分析设计。药品销售系统的主要使用者分为管理员、用户和医生,实现功能包括管理员;管理员个人中心、用户管理、医生管理、药品信息管理、药品分类管理、订单配送管理、系统管理、订单管理,用户;个人中心、订单配送管理、订单管理,医生:个人中心、药品信息管理、药品分类管理,前台首页:首页、药品信息、我的、跳转到后台、购物车、客服等功能。系统中管理员主要是为了安全有效地存储和管理各类信息,还可以对系统进行管理与更新维护等操作,并且对后台有相应的操作权限。要想实现药品销售系统的各项功能,需要后台数据库的大力支持。管理员验证注册信息,收集的用户信息,并由此分析得出的关联信息等大量的数据都由数据库管理。本文中数据库服务器端采用了Mysql作为后台数据库,使Web与数据库紧密联系起来。在设计过程中,充分保证了系统代码的良好可读性、实用性、易扩展性、通用性、便于后期维护、操作方便以及页面简洁等特点。
本系统的开发使获取药品销售系统信息能够更加方便快捷,同时也使药品销售系统信息变的更加系统化、有序化。系统界面较友好,易于操作。
功能设计
功能模块图
药品销售系统基于Web服务模式,是一个适用于Internet环境下的模型结构。只要用户能连上Internet,便可以在不受时间、地点的限制来使用这个系统。药品销售系统工作原理图
本系统架构网站系统
管理员功能结构图
用户功能结构图
医生功能结构图
管理员信息结构图
医生信息实体属性图
用户信息实体属性图
功能截图
管理员登录,管理员通过输入用户名、密码、角色等信息进行系统登录
管理员登录进入药品销售系统可以查看;个人中心、用户管理、医生管理、药品信息管理、药品分类管理、订单配送管理、系统管理、订单管理等内容
个人信息,个人信息页面可以填写原密码、新密码、确认密码等内容,并可根据需要对个人信息 进行添加,修改等操作
用户管理,管理员通过用户管理页面可以查看账号、姓名、性别、手机、邮箱、身份证、图片、地址、余额等内容,并可根据需要对用户管理进行添加,修改或删除等操作
医生管理,管理员通过在医生管理页面可以查看医生账号、医生姓名、职称、性别、医龄、手机、身份证、头像、简介、余额等操作,并可根据需要对医生管理进行添加,修改或删除等操作
药品信息管理,管理员通过在药品信息管理页面可以查看药品编号、药品名称、药品分类、批次号、生产日期、药品价格、药品说明、生产单位、生产地址、药品图片、有效期至、价格等内容,并可根据需要对药品信息管理信息进行添加,修改,删除或详细内容等操作
药品分类管理 ,管理员通过在药品分类管理页面可以查看分类、操作等内容,并可根据需要对药品分类管理进行添加,修改,删除或详细内容等操作
订单配送管理,管理员通过在订单配送管理页面可以查看退货单号、商品名称、品牌、图片、数量、退货日期、客户编号、客户姓名、联系电话等内容,并可根据需要订单配送管理进行添加,修改,删除或详细内容等操作
轮播图管理管理,管理员通过在轮播图管理管理页面可以查看名称、值等内容,并可根据需要对轮播图管理管理进行添加,修改,删除或详细内容等操作
用户登录进入药品销售系统可以查看;个人中心、订单配送管理、订单管理操作等内容
订单配送管理,在订单配送管理页面通过填写订单编号、药品编号、药品名称、账号、姓名、手机、下单时间、预估收货时间、收货地址、订单状态、经度、纬度、地址等内容并可根据需要对订单配送管理进行查看
订单管理,在订单管理页面可以填写订单编号、商品表名、用户id、商品id、商品名称、商品图片、购买数量价格、积分折扣价格、总价格、总积分、折扣价格支付类型、状态、地址等内容,并可根据需要对订单管理详细内容操作
医生登录进入药品销售系统可以查看;个人中心、药品信息管理、药品分类管理操作等内容
药品信息管理,医生通过在药品信息管理页面可以查看药品编号、药品名称、药品分类、批次号、生产日期、药品价格、药品说明、生产单位、生产地址、药品图片、有效期至、价格等内容,并可根据需要对药品信息管理信息进行添加,修改,删除或详细内容等操作
药品分类管理,医生通过在药品分类管理页面可以查看分类、操作等内容,并可根据需要对药品分类管理进行添加,查看详细内容等操作
前台首页,在系统首页可以查看首页、药品信息、我的、跳转到后台、购物车、客服等内容
用户注册、登录,在注册页面通过填写账号、姓名、性别、手机、邮箱、身份证、图片、地址等信息完成注册,信息无误进行登陆
药品信息管理,在药品信息管理页面可以查看药品编号、药品名称、药品分类、批次号、生产日期、药品价格、药品说明、生产单位、生产地址、药品图片、有效期至、价格等内容,也可根据需要输入药品信息进行搜索操作
我的,在我的页面可以查看账号、姓名、性别、手机、邮箱、身份证、图片、地址内容,可进行添加、修改、删除操作
相关代码
数据库配置
# Tomcat
server:tomcat:uri-encoding: UTF-8port: 8080servlet:context-path: /springbootr1tjfspring:datasource:driverClassName: com.mysql.jdbc.Driverurl: jdbc:mysql://127.0.0.1:3306/springbootr1tjf?useUnicode=true&characterEncoding=utf-8&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=GMT%2B8username: rootpassword: 123456# driverClassName: com.microsoft.sqlserver.jdbc.SQLServerDriver
# url: jdbc:sqlserver://127.0.0.1:1433;DatabaseName=springbootr1tjf
# username: sa
# password: 123456servlet:multipart:max-file-size: 10MBmax-request-size: 10MBresources:static-locations: classpath:static/,file:static/#mybatis
mybatis-plus:mapper-locations: classpath*:mapper/*.xml#实体扫描,多个package用逗号或者分号分隔typeAliasesPackage: com.entityglobal-config:#主键类型 0:"数据库ID自增", 1:"用户输入ID",2:"全局唯一ID (数字类型唯一ID)", 3:"全局唯一ID UUID";id-type: 1#字段策略 0:"忽略判断",1:"非 NULL 判断"),2:"非空判断"field-strategy: 2#驼峰下划线转换db-column-underline: true#刷新mapper 调试神器refresh-mapper: true#逻辑删除配置logic-delete-value: -1logic-not-delete-value: 0#自定义SQL注入器sql-injector: com.baomidou.mybatisplus.mapper.LogicSqlInjectorconfiguration:map-underscore-to-camel-case: truecache-enabled: falsecall-setters-on-nulls: true#springboot 项目mybatis plus 设置 jdbcTypeForNull (oracle数据库需配置JdbcType.NULL, 默认是Other)jdbc-type-for-null: 'null'
控制层(controller)
package com.controller;import java.util.Arrays;
import java.util.Calendar;
import java.util.Date;
import java.util.Map;import javax.servlet.http.HttpServletRequest;import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;import com.annotation.IgnoreAuth;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.entity.TokenEntity;
import com.entity.UserEntity;
import com.service.TokenService;
import com.service.UserService;
import com.utils.CommonUtil;
import com.utils.MPUtil;
import com.utils.PageUtils;
import com.utils.R;
import com.utils.ValidatorUtils;/*** 登录相关*/
@RequestMapping("users")
@RestController
public class UserController{@Autowiredprivate UserService userService;@Autowiredprivate TokenService tokenService;/*** 登录*/@IgnoreAuth@PostMapping(value = "/login")public R login(String username, String password, String captcha, HttpServletRequest request) {UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));if(user==null || !user.getPassword().equals(password)) {return R.error("账号或密码不正确");}String token = tokenService.generateToken(user.getId(),username, "users", user.getRole());return R.ok().put("token", token);}/*** 注册*/@IgnoreAuth@PostMapping(value = "/register")public R register(@RequestBody UserEntity user){// ValidatorUtils.validateEntity(user);if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {return R.error("用户已存在");}userService.insert(user);return R.ok();}/*** 退出*/@GetMapping(value = "logout")public R logout(HttpServletRequest request) {request.getSession().invalidate();return R.ok("退出成功");}/*** 密码重置*/@IgnoreAuth@RequestMapping(value = "/resetPass")public R resetPass(String username, HttpServletRequest request){UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));if(user==null) {return R.error("账号不存在");}user.setPassword("123456");userService.update(user,null);return R.ok("密码已重置为:123456");}/*** 列表*/@RequestMapping("/page")public R page(@RequestParam Map<String, Object> params,UserEntity user){EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();PageUtils page = userService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.allLike(ew, user), params), params));return R.ok().put("data", page);}/*** 列表*/@RequestMapping("/list")public R list( UserEntity user){EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();ew.allEq(MPUtil.allEQMapPre( user, "user")); return R.ok().put("data", userService.selectListView(ew));}/*** 信息*/@RequestMapping("/info/{id}")public R info(@PathVariable("id") String id){UserEntity user = userService.selectById(id);return R.ok().put("data", user);}/*** 获取用户的session用户信息*/@RequestMapping("/session")public R getCurrUser(HttpServletRequest request){Long id = (Long)request.getSession().getAttribute("userId");UserEntity user = userService.selectById(id);return R.ok().put("data", user);}/*** 保存*/@PostMapping("/save")public R save(@RequestBody UserEntity user){// ValidatorUtils.validateEntity(user);if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {return R.error("用户已存在");}userService.insert(user);return R.ok();}/*** 修改*/@RequestMapping("/update")public R update(@RequestBody UserEntity user){// ValidatorUtils.validateEntity(user);UserEntity u = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername()));if(u!=null && u.getId()!=user.getId() && u.getUsername().equals(user.getUsername())) {return R.error("用户名已存在。");}userService.updateById(user);//全部更新return R.ok();}/*** 删除*/@RequestMapping("/delete")public R delete(@RequestBody Long[] ids){userService.deleteBatchIds(Arrays.asList(ids));return R.ok();}
}
业务层(Service)
package com.service;import java.util.List;
import java.util.Map;import org.apache.ibatis.annotations.Param;import com.baomidou.mybatisplus.mapper.Wrapper;
import com.baomidou.mybatisplus.service.IService;
import com.entity.UserEntity;
import com.utils.PageUtils;/*** 系统用户*/
public interface UserService extends IService<UserEntity> {PageUtils queryPage(Map<String, Object> params);List<UserEntity> selectListView(Wrapper<UserEntity> wrapper);PageUtils queryPage(Map<String, Object> params,Wrapper<UserEntity> wrapper);}
数据访问层(Dao)
package com.dao;import java.util.List;import org.apache.ibatis.annotations.Param;import com.baomidou.mybatisplus.mapper.BaseMapper;
import com.baomidou.mybatisplus.mapper.Wrapper;
import com.baomidou.mybatisplus.plugins.pagination.Pagination;
import com.entity.UserEntity;/*** 用户*/
public interface UserDao extends BaseMapper<UserEntity> {List<UserEntity> selectListView(@Param("ew") Wrapper<UserEntity> wrapper);List<UserEntity> selectListView(Pagination page,@Param("ew") Wrapper<UserEntity> wrapper);}
Java-基于SSM的药品销售管理系统相关推荐
- 基于ssm框架超市销售管理系统
Java 基于ssm框架超市销售管理系统 1. 此系统是基于J2EE的会员管理系统 :根据实际需求,通过建立一些相关的接口,对相关功能进行实现,同时可采用框架技术进行合理的搭建设计,能简化代码的实现, ...
- 基于SSM开发医药销售管理系统
基于SSM开发医药销售管理系统:(毕业设计/课程设计) 开发环境: Windows操作系统 开发工具: MyEclipse(Eclipse)+Jdk+Tomcat+MYSQL数据库 运行效果图: 基于 ...
- java基于ssm的健身房会员管理系统
设计基于ssm的健身房会员管理系统的主要目的是为了方便健身房对会员.课程安排.通知等的实际情况进行集中的查询与管理工作,以提高整个健身房的工作效率.主要由会员管理系统和管理员管理系统组成.其中会员管理 ...
- java基于ssm的学校教务管理系统的设计与实现论文-计算机毕业设计
学校教务管理系统的设计与实现 摘 要 学校教务管理信息化是提高办公效率的主要途径,随着我国高等教育的快速发展,学校办学规模的不断扩大,在校学生人数不断增多,办学层次出现多元化,由一地办学发展到多地多点 ...
- 基于ssm的服装销售管理系统毕业论文
答:根据<SSM服装销售管理系统毕业论文>,本文旨在设计一个基于服装销售管理的系统,用于收集信息并进行服装销售管理,以提高服装销售的效率,降低成本,提高客户满意度.为此,本文探讨了SSM技 ...
- java基于ssm的宠物用品商城管理系统 springboot vue
宠物用品商城管理系统是基于java编程语言,mysql数据库,SSM框架设计,系统分类用户,管理员,商家三个角色,用户可以注册登陆后,购买宠物用品,生成订单,在线留言反馈,发布交流帖子.商家可以注册登 ...
- 期未课程设计:基于SSM的产品销售管理系统
项目编号:KS005 本项目基于SSM框架(spring+springmvc+mybatis)进行开发实现,前端使用bootstrap+jsp来进行页面的开发实现,数据库采用MYSQL,开发工具为ec ...
- java基于ssm的水产品配送管理系统
本水产品配送管理系统通过Web方式完成用户与系统的交互,系统的功能模块具体有水产品分类管理模块.车辆信息管理模块.配送信息模块.线路管理模块. 本主要编程语言为java和mysql. JDK版本是1. ...
- java 基于ssm二手车评估交易管理系统
二手车交易管理系统是基于java编程语言,mysql数据库,ssm框架设计,本系统主要分为用户和管理员两个角色,其中用户的功能有用户注册和登陆系统,用户查网站新闻,查看二手车,在线预定,提交自己的二手 ...
最新文章
- Swift中出现“no such module cocoa”的错误
- 绝症老父亲即将说不了话,儿子用AI技术挽留他的声音
- 想拥有最新的微软嵌入式技术 就赶快加入微软嵌入式专家社区吧!
- 通过SUBMIT获取ALV GRID的数据
- linux 开机自动启动服务
- SAP CRM schedule line i
- SilverLight非托管代码的初始化进度条方法
- ux的重要性_UX中清晰的重要性
- 复化梯形公式matlab程序_【HPC】高性能数值计算-梯形面积法
- log4j 禁止类输出日志_springboot日志详解
- 改良程序需要的11个技巧
- Ubuntu9.04升级到9.10后的问题及其解决方法
- html 显示动态时间
- 家庭多房间网线连接---小白快速上手
- 3D打印将对零售模式产生颠覆影响,能否抓住机遇
- spss clementine安装
- 域用户桌面显示计算机名,用Bginfo设置域客户端桌面显示主机名和IP地址信息
- uC/OS-III 内核实现与应用开发实战学习(一)
- Android Switch控件修改样式
- 了解小猪cms文件结构
热门文章
- OpenGL入门教程 - 01
- vue ivew + spring boot合并pdf文件
- Python入门--程序控制-选择结构
- Emscripten的研究与学习 --- 初探Emscripten
- X86逆向14:常见的脱壳手法
- 学海领航c语言答案,学海领航语文单元测试卷答案.doc
- java 匿名类调用方法_Java匿名内部类使用与示例
- PostgreSQL 9X之巅(原书第2版)
- 万元内买断管理软件“全家桶”还“包定制”:SaaS新风向?
- windows访问共享文件夹 登录失败: 禁用当前的账户 解决方法