口腔和牙齿是关乎人一身健康的重要因素,只有有好的牙齿才能吃到更多美味的食品,从而获取到更加充分的营养,但是人类的牙齿一般都只更换一次,即从乳牙到恒牙的更换过程,为了让更多的人通过更加合理的方式来保护自己的牙齿,我们通过Java语言开发了本次的基于Springboot+vue的个人口腔牙齿卫生保护产品销售购物网站。在本系统中不仅可以学习到更多的保护牙齿的知识,而且还可以购买一些家庭内部使用的牙齿保护产品,从而提高牙齿的寿命 系统实现管理员:首页、个人中心、会员管理、病例就诊信息管理、牙齿保健产品管理、复查提醒管理、预约挂号管理、药品信息管理、留言板管理、系统管理、订单管理,会员:首页、个人中心、病例就诊信息管理、复查提醒管理、预约挂号管理、我的收藏管理、订单管理,前台首页:首页、牙齿保健产品、牙齿保护小知识、留言反馈、个人中心、后台管理、购物车功能。从而达到对口腔管理平台信息的高效管理。
环境需要 1.运行环境:最好是java jdk 1.8,这是目前最稳定的JDK也是被使用最多的JDK版本。 2.IDE环境:IDEA,Eclipse都可以。推荐IDEA; 3.tomcat环境:Tomcat7/Tomcat8/Tomcat9版本均可 4.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS; 5.数据库:MySql 5.7版本; 6.是否Maven项目:是; 技术栈 后端:Spring+SpringMVC+Mybatis+Springboot 前端:vue+CSS+JavaScript+jQuery+elementui
前台首页功能模块
口腔管理平台,在口腔管理平台可以查看首页、牙齿保健产品、牙齿保护小知识、留言反馈、个人中心、后台管理、购物车等内容 登录、会员注册,通过会员注册获取会员号、密码、姓名、年龄、手机、邮箱等信息进行注册、登录 牙齿保健产品,在牙齿保健产品页面可以填写产品名称、价格、产品编号、产品类型、积分、适用人群、使用方法、注意事项等信息进行立即购买 确认下单,在确认下单页面可以填写选择收货地址、清单列表等进行支付如图 收货地址添加,在收货地址添加页面可以填写联系人、手机号码、默认地址、选择地址等信息进行添加
管理员功能模块
管理员登录,通过填写注册时输入的用户名、密码、角色进行登录
管理员登录进入口腔管理平台可以查看首页、个人中心、会员管理、病例就诊信息管理、牙齿保健产品管理、复查提醒管理、预约挂号管理、药品信息管理
留言板管理、系统管理、订单管理等信息。
个人中心,在个人中心页面中可以通过填写原密码、新密码、确认密码等信息进行添加、修改1所示。还可以根据需要对个人信息进行添加,修改或删除等详细操作 2
会员管理,在会员管理页面中可以查看会员号、姓名、性别、手机、年龄、性别、手机、邮箱、积分等信息,并可根据需要对会员管理进行详情、修改或删除等操作
病例就诊信息管理,在病例就诊信息管理页面中可以查看会员号、姓名、性别、手机、年龄、身份证、药品用量、就诊信息、就诊时间等信息,并可根据需要对病例就诊信息管理进行详情、修改或删除等详细操作
牙齿保健产品管理,在牙齿保健产品管理页面中可以查看产品编号、产品名称、产品类型、图片、积分、适用人群、使用方法、注意事项等内容,并且根据需要对牙齿保健产品管理进行详情、添加,修改或删除等详细操作
轮播图 :该页面为轮播图管理界面。管理员可以在此页面进行首页轮播图的管理,通过新建操作可在轮播图中加入新的图片,还可以对以上传的图片进行修改操作,以及图片的删除操作
预约挂号管理,在预约挂号管理页面中可以查看会员号、姓名、预约就诊时间、备注、审核回复、审核状态、审核等内容,并且根据需要对预约挂号管理进行详情、添加,修改或删除等详细操作
药品信息管理,在药品信息管理页面中可以查看药品编号、药品名称、图片、备注、功能主治、不良反应、禁忌事项等内容,并且根据需要对药品信息管理进行详情、添加,修改或删除等详细操作
留言板管理,在留言板管理页面中可以查看用户名、留言内容、回复内容等内容,并且根据需要对留言板管理进行详情、添加,修改或删除等详细操作
1、管理员账号:abo 密码:abo 2、开发环境为Eclipse/idea,数据库为mysql 使用java语言开发。 3.运行SpringbootSchemaApplication.java 即可打开首页 4.数据库连接src\main\resources\application.yml中修改 5.maven包版本apache-maven-3.3.9. 开发语言:Java 框架:springboot 前端框架:vue.js JDK版本:JDK1.8+ 服务器:tomcat8+ 数据库工具:Navicat 开发软件:idea 支持eclipse
会员功能模块
会员登录进入口腔管理平台可以查看首页、个人中心、病例就诊信息管理、复查提醒管理、预约挂号管理、我的收藏管理、订单管理等内容。 个人信息,在个人信息页面中通过填写会员号、姓名、性别、手机、年龄、性别、手机、邮箱、积分等信息还可以根据需要对个人信息进行修改 我的收藏管理,在我的收藏管理页面中可以查看收藏ID、表名、收藏名称、收藏图片等信息内容,并且根据需要对我的收藏管理进行修改或删除等其他详细操作 预约挂号管理,在预约挂号管理页面中通过填写会员号、姓名、预约就诊时间、备注、审核回复、审核状态、审核等内容进行详情、删除 订单管理,在订单管理页面中通过填写订单编号、商品名称、商品图片、购买数量、价格/积分、折扣价格、总价格/总积分、折扣总价格、支付类型、状态、地址等内容进行详情、删除
` /**
登录相关 */ @RequestMapping(“users”) @RestController public class UserController{
@Autowired private UserService userService;
@Autowired private TokenService tokenService;
/**
登录 */ @IgnoreAuth @PostMapping(value = “/login”) public R login(String username, String password, String captcha, HttpServletRequest request) { UserEntity user = userService.selectOne(new EntityWrapper().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().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().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 params,UserEntity user){ EntityWrapper ew = new EntityWrapper(); 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 ew = new EntityWrapper(); 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().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); userService.updateById(user);//全部更新 return R.ok(); } /**
删除 */ @RequestMapping(“/delete”) public R delete(@RequestBody Long[] ids){ userService.deleteBatchIds(Arrays.asList(ids)); return R.ok(); } } `
目录 1 绪论 1 1.1课题背景 1 1.2课题研究现状 1 1.3初步设计方法与实施方案 2 1.4本文研究内容 2 2 系统开发环境 4 2.1 使用工具简介 4 2.2 环境配置 4 2.3 B/S结构简介 4 2.4 MySQL数据库 5 2.5 框架介绍 5 3 系统分析 6 3.1系统可行性分析 6 3.1.1经济可行性 6 3.1.2技术可行性 6 3.1.3运行可行性 6 3.2系统现状分析 6 3.3功能需求分析 7 3.4系统设计规则与运行环境 8 3.5系统流程分析 8 3.5.1操作流程 8 3.5.2添加信息流程 9 3.5.3删除信息流程 10 4 系统设计 11 4.1系统设计主要功能 11 4.2数据库设计 11 4.2.1数据库设计规范 11 4.2.2 E/R图 11 4.2.3数据表 12 5 系统实现 25 5.1系统功能模块 25 5.2后台模块 27 5.2.1管理员功能模块 27 5.2.2用户功能模块 30 6 系统测试 33 6.1功能测试 33 6.2可用性测试 33 6.3性能测试 34 6.4测试结果分析 34 7结 论 35 参考文献 36 致 谢 37