项目背景

本论文主要论述了如何使用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的药品销售管理系统相关推荐

  1. 基于ssm框架超市销售管理系统

    Java 基于ssm框架超市销售管理系统 1. 此系统是基于J2EE的会员管理系统 :根据实际需求,通过建立一些相关的接口,对相关功能进行实现,同时可采用框架技术进行合理的搭建设计,能简化代码的实现, ...

  2. 基于SSM开发医药销售管理系统

    基于SSM开发医药销售管理系统:(毕业设计/课程设计) 开发环境: Windows操作系统 开发工具: MyEclipse(Eclipse)+Jdk+Tomcat+MYSQL数据库 运行效果图: 基于 ...

  3. java基于ssm的健身房会员管理系统

    设计基于ssm的健身房会员管理系统的主要目的是为了方便健身房对会员.课程安排.通知等的实际情况进行集中的查询与管理工作,以提高整个健身房的工作效率.主要由会员管理系统和管理员管理系统组成.其中会员管理 ...

  4. java基于ssm的学校教务管理系统的设计与实现论文-计算机毕业设计

    学校教务管理系统的设计与实现 摘 要 学校教务管理信息化是提高办公效率的主要途径,随着我国高等教育的快速发展,学校办学规模的不断扩大,在校学生人数不断增多,办学层次出现多元化,由一地办学发展到多地多点 ...

  5. 基于ssm的服装销售管理系统毕业论文

    答:根据<SSM服装销售管理系统毕业论文>,本文旨在设计一个基于服装销售管理的系统,用于收集信息并进行服装销售管理,以提高服装销售的效率,降低成本,提高客户满意度.为此,本文探讨了SSM技 ...

  6. java基于ssm的宠物用品商城管理系统 springboot vue

    宠物用品商城管理系统是基于java编程语言,mysql数据库,SSM框架设计,系统分类用户,管理员,商家三个角色,用户可以注册登陆后,购买宠物用品,生成订单,在线留言反馈,发布交流帖子.商家可以注册登 ...

  7. 期未课程设计:基于SSM的产品销售管理系统

    项目编号:KS005 本项目基于SSM框架(spring+springmvc+mybatis)进行开发实现,前端使用bootstrap+jsp来进行页面的开发实现,数据库采用MYSQL,开发工具为ec ...

  8. java基于ssm的水产品配送管理系统

    本水产品配送管理系统通过Web方式完成用户与系统的交互,系统的功能模块具体有水产品分类管理模块.车辆信息管理模块.配送信息模块.线路管理模块. 本主要编程语言为java和mysql. JDK版本是1. ...

  9. java 基于ssm二手车评估交易管理系统

    二手车交易管理系统是基于java编程语言,mysql数据库,ssm框架设计,本系统主要分为用户和管理员两个角色,其中用户的功能有用户注册和登陆系统,用户查网站新闻,查看二手车,在线预定,提交自己的二手 ...

最新文章

  1. Swift中出现“no such module cocoa”的错误
  2. 绝症老父亲即将说不了话,儿子用AI技术挽留他的声音
  3. 想拥有最新的微软嵌入式技术 就赶快加入微软嵌入式专家社区吧!
  4. 通过SUBMIT获取ALV GRID的数据
  5. linux 开机自动启动服务
  6. SAP CRM schedule line i
  7. SilverLight非托管代码的初始化进度条方法
  8. ux的重要性_UX中清晰的重要性
  9. 复化梯形公式matlab程序_【HPC】高性能数值计算-梯形面积法
  10. log4j 禁止类输出日志_springboot日志详解
  11. 改良程序需要的11个技巧
  12. Ubuntu9.04升级到9.10后的问题及其解决方法
  13. html 显示动态时间
  14. 家庭多房间网线连接---小白快速上手
  15. 3D打印将对零售模式产生颠覆影响,能否抓住机遇
  16. spss clementine安装
  17. 域用户桌面显示计算机名,用Bginfo设置域客户端桌面显示主机名和IP地址信息
  18. uC/OS-III 内核实现与应用开发实战学习(一)
  19. Android Switch控件修改样式
  20. 了解小猪cms文件结构

热门文章

  1. OpenGL入门教程 - 01
  2. vue ivew + spring boot合并pdf文件
  3. Python入门--程序控制-选择结构
  4. Emscripten的研究与学习 --- 初探Emscripten
  5. X86逆向14:常见的脱壳手法
  6. 学海领航c语言答案,学海领航语文单元测试卷答案.doc
  7. java 匿名类调用方法_Java匿名内部类使用与示例
  8. PostgreSQL 9X之巅(原书第2版)
  9. 万元内买断管理软件“全家桶”还“包定制”:SaaS新风向?
  10. windows访问共享文件夹 登录失败: 禁用当前的账户 解决方法