当前,由于人们生活水平的提高和思想观念的改变,然后随着经济全球化的背景之下,互联网技术将进一步提高社会综合发展的效率和速度,互联网技术也会涉及到各个领域,于是传统的管理方式对时间、地点的限制太多,而微信小程序刚好能满足这些需求,微信小程序突破了传统管理方式的局限性。
更重要的是,互联网技术和物联网技术的发展使得用户使用微信小程序的微医平台变得更加便捷、高效、智能。基于这种背景,本系统采用了B/S架构模式、微信开发者,使用 springboot框架,搭建了Java运行环境和Tomcat服务器,并选择MySQL轻量级数据库作为数据存储媒介。通过这些技术手段,可以保证系统的高效性和稳定性,并且为用户提供良好的体验和高效的管理能力。
总的来说,本系统旨在提高本行业的管理效率和信息化管理,此外,本文的设计与实现也为相关领域的研究提供了借鉴和参考。通过实践中的应用和优化,本系统可为用户放心使用。
关键词:微信小程序的微医平台;springboot框架;MySQL数据库;
程序上交给用户进行使用时,需要提供程序的操作流程图,这样便于用户容易理解程序的具体工作步骤,现如今程序的操作流程都有一个大致的标准,即先通过登录页面提交登录数据,通过程序验证正确之后,用户才能在程序功能操作区页面操作对应的功能。
程序操作流程图
首先前端通过Vue和axios发送HTTP请求到后端的登录接口。在后端接收登录请求的Controller会使用`@RequestParam Map<String, Object> params`来接收前端传递的用户参数,用户名和密码。然后后端根据接收到的参数创建一个查询条件封装对象MyBatis的EntityWrapper用于构建查询条件。接着在业务层,调用相应的service方法来查询数据库中是否存在匹配的用户信息。这个查询方法Login()会将前端传递的对象参数传递到后台的DAO层,进行数据库的交互操作。如果存在符合条件的用户,则会返回相关的用户信息。最后在后端控制器中将查询结果封装成响应体,通过`return R.ok().put("data", userService.selecView(ew))`将用户信息返回给前端。前端收到响应后,可以通过调用Vue、ElementUI等组件来渲染登录结果,例如显示用户信息或者跳转到相应的页面。
系统架构设计是软件开发过程中至关重要的一环。首先是模型层(Model),模型层通常对应着数据库或者其他数据源,它负责与数据库进行交互,执行各种数据操作,并将处理后的数据传递给控制器层。模型层的设计应该简洁清晰,尽可能减少与视图和控制器的耦合,以提高代码的可维护性和可重用性。
其次是视图层(View)通常是通过网页、移动应用界面或者其他用户界面来展示数据。视图层与用户交互,接受用户的输入,并将输入传递给控制器层进行处理。在MVC三层架构中,视图层应该尽量保持简单,只负责数据的展示和用户交互,不涉及业务逻辑的处理,以保持视图层的清晰度和可复用性,最后是控制器层(Controller),每个层都有特定的职责和功能,通过分层架构设计,实现代码模块化,为软件开发提供了一种有效的架构模式。系统架构如图4-1所示。
请文末卡片dd我获取更详细的演示视频
当用户第一次进入该微信端时,须先进行系统的账号注册。该微信小程序的微医平台的注册流程包括设置用户的账号和密码,同时也需要填写用户账号、用户姓名等信息。只有正确输入完整的信息之后才能进行登录,再把微信端输入的信息与数据库内注册的账号信息比对,通过RegisterController验证通过之后也将会跳转至微信端首页。注册功能实现页面如图5.1所示:
图5.1 用户注册功能实现图
为了享受微信小程序的微医平台的所有功能和服务,用户需要先进行登录。在登录页面中,用户需输入账号、密码以及选择用户权限,以便系统与数据库中相关信息进行验证。若验证成功,系统将跳转至主页页面,用户即可开始使用系统;若验证失败,系统会自动跳转回登录页面,并提示用户未通过验证的原因,避免重复错误。
从技术实现角度来看,当系统接收到用户登录请求时,会调用LoginController进行判断。若验证通过,则会跳转到主页页面,若未通过则重新跳转回登录页面,直到验证通过为止。这样的流程设计可以保证用户的信息安全,并提高系统的稳定性和可靠性。登录功能实现页面如图5.2所示:
图5.2 用户登录功能实现图
注册账号成功且登录微信端后,用户即可进入微信端主页查看首页、出诊医生、皮肤科专区、购物车、我的,并开始执行业务操作,微信小程序的微医平台首页功能实现如图5.3所示:
图5.3 微信端首页功能实现图
在出诊医生页面的搜索栏输入医生账号、医生姓名、照片、年龄、性别、科室、票额、挂号费、上班时间、出诊日期、点击次数、收藏数,进行查询,可以查看出诊医生等信息,还可以进行预约挂号、联系TA、收藏等操作;如图5.4所示:
图5.4出诊医生功能实现图
在皮肤科专区页面的搜索栏输入专家账号、专家姓名、照片、年龄、性别、联系电话、专区分类、上班时间、点击次数、收藏数,进行查询,可以查看皮肤科专区等信息,也可以点击收藏等操作,如图5.5所示:
图5.5皮肤科专区功能实现图
当用户在我的页面中,可以对我的订单、预约挂号、就诊记录、三甲体检申请、我的收藏、用户充值、聊天记录、修改密码等这些功能任意查询。如图5.6所示:
图5.6 我的功能实现图
管理员登录,在登录页面选择需要登录的角色,在正确输入用户名和密码后,管理员登录功能实现图如图5.7所示:
图5.7管理员登录功能实现图
当管理员登录时,需选择管理员身份权限。系统将会调用LoginController进行判断,并对输入的信息与数据库中的相关信息进行比对。若验证通过,则会自动跳转至管理员主页面;若未能通过验证,则会重新跳转至登录页面并给出相应的验证失败提示,以避免再次出现同样的错误。管理员功能实现页面如图5.8所示:
图5.8管理员功能实现图
管理员点击用户,在用户页面中输入账号、姓名、年龄、性别、手机、身份证、头像,进行搜索,然后查看用户等信息,也可以点击添加或删除等操作。如图5.9所示:
图5.9用户功能实现图
管理员点击医生,在医生页面中输入医生账号、医生姓名、年龄、科室、性别、联系电话、头像,进行搜索,然后查看医生等信息,也可以点击添加或删除等操作。如图5.10所示:
图5.10 医生功能实现图
管理员点击出诊医生,在出诊医生页面中输入医生账号、医生姓名、照片、年龄、性别、科室、票额、挂号费、上班时间、出诊日期、点击次数、收藏数,进行搜索,然后查看出诊医生等信息,也可以点击添加或删除等操作。如图5.11所示:
图5.11出诊医生功能实现图
管理员点击就诊记录,在就诊记录页面中输入就诊编号、科室、医生账号、医生姓名、账号、姓名、手机、性别、年龄、身份证、头像、就诊日期,进行搜索,然后查看就诊记录等信息,也可以点击删除等操作。如图5.12所示:
图5.12就诊记录功能实现图
图5.13药品信息功能实现图
管理员点击药品类别,在药品类别页面中输入药品类别,进行搜索,然后查看药品类别等信息,也可以点击添加、删除等操作。如图5.14所示:
图5.14药品类别功能实现图
/**
* 登录相关
*/
@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 role, HttpServletRequest request) {
UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
if(user != null){
if(!user.getRole().equals(role)){
return R.error("权限不正常");
}
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);
}else{
return R.error("账号或密码或权限不对");
}
}
/**
* 注册
*/
@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("/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){
Integer id = (Integer)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);
userService.updateById(user);//全部更新
return R.ok();
}
/**
* 删除
*/
@RequestMapping("/delete")
public R delete(@RequestBody Integer[] ids){
userService.deleteBatchIds(Arrays.asList(ids));
return R.ok();
}
}
大家点赞、收藏、关注、评论啦 、查看??获取联系方式??
精彩专栏推荐订阅:在下方专栏??