• 计算机毕业设计springboot+vue基本微信小程序的透析耗材管理系统


    项目介绍

    随着信息技术和网络技术的飞速发展,人类已进入全新信息化时代,传统管理技术已无法高效,便捷地管理信息。为了迎合时代需求,优化管理效率,各种各样的管理程序应运而生,各行各业相继进入信息管理时代,透析耗材管理小程序就是信息时代变革中的产物之一。
    任何程序都要遵循程序设计的基本流程,本程序也不例外,同样需要经过市场调研,需求分析,概要设计,详细设计,编码,测试这些步骤,基于Java语言、微信小程序技术设计并实现了透析耗材管理小程序。程序主要包括首页、个人中心、医生护士管理、设备类型管理、耗材设备管理、耗材申请管理、设备入库管理、设备出库管理、设备盘点管理、设备保养管理、系统管理等功能模块。
    本文首先介绍了透析耗材管理小程序技术的发展背景与发展现状,然后遵循软件常规开发流程,首先针对程序选取适用的语言和开发平台,根据需求分析制定模块并设计数据库结构,再根据程序总体功能模块的设计绘制程序的功能模块图,流程图以及E-R图。然后,设计框架并根据设计的框架编写代码以实现程序的各个功能模块。最后,对初步完成的程序进行测试,主要是功能测试、单元测试和性能测试。测试结果表明,该程序能够实现所需的功能,运行状况尚可并无明显缺点。

    开发说明:前端使用微信微信小程序开发工具;后端使用springboot+VUE开发
    开发语言:Java
    开发工具:IDEA /Eclipse/微信小程序开发工具
    数据库:MYSQL5.7或以上
    应用服务:Tomcat8或以上

    功能介绍

    考虑到实际生活中透析耗材管理小程序方面的需要以及对该小程序认真的分析,将小程序权限按管理员和用户这两类涉及用户划分。
    (a) 管理员;管理员使用本程序涉到的功能主要有:个人中心、医生护士管理、设备类型管理、耗材设备管理、耗材申请管理、设备入库管理等功能。
    (b)用户进入程序前台可以实现首页、耗材设备、新闻资讯、我的等功能。
    请添加图片描述

    部分代码

    /**
     * 登录相关
     */
    @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<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();
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
    • 85
    • 86
    • 87
    • 88
    • 89
    • 90
    • 91
    • 92
    • 93
    • 94
    • 95
    • 96
    • 97
    • 98
    • 99
    • 100
    • 101
    • 102
    • 103
    • 104
    • 105
    • 106
    • 107
    • 108
    • 109
    • 110
    • 111
    • 112
    • 113
    • 114
    • 115
    • 116
    • 117
    • 118
    • 119
    • 120
    • 121
    • 122
    • 123
    • 124
    • 125
    • 126
    • 127
    • 128
    • 129
    • 130
    • 131
    • 132
    • 133
    • 134
    • 135
    • 136
    • 137
    • 138
    • 139
    • 140

    效果图

    请添加图片描述
    请添加图片描述

    请添加图片描述
    请添加图片描述
    请添加图片描述
    目 录
    1绪论 1
    1.1项目研究的背景 1
    1.2开发意义 1
    1.3项目研究现状及内容 5
    1.4论文结构 5
    2开发技术介绍 7
    2.1 B/S架构 7
    2.2 MySQL 介绍 7
    2.3 MySQL环境配置 7
    2.4 Java语言简介 8
    2.5微信小程序技术 8
    3程序分析 9
    3.1可行性分析 9
    3.1.1技术可行性 9
    3.1.2经济可行性 9
    3.1.3操作可行性 10
    3.2网站性能需求分析 10
    3.3网站功能分析 10
    3.4程序流程的分析 11
    3.4.1 医生护士管理的流程 12
    3.4.2 个人中心管理流程 13
    3.4.3 登录流程 13
    4程序设计 14
    4.1 软件功能模块设计 14
    4.2 数据库设计 13
    4.2.1 概念模型设计 13
    4.2.2 物理模型设计 15
    5程序详细设计 21
    5.1程序前台功能模块 21
    5.2管理员功能模块 24
    6程序测试 30
    7总结与心得体会 33
    7.1 总结 33
    7.2 心得体会 33
    参考文献 35
    致谢 36

  • 相关阅读:
    SPARKSQL3.0-Antlr4由浅入深&SparkSQL语法解析
    什么是埃及COC认证?埃及COC认证是什么意思?
    基于SSM+Vue的体育馆管理系统的设计与实现
    Linux 物理页struct page
    南京数字孪生赋能工业制造,加速推进制造业数字化转型
    专业硕士招生占比将达到三分之二,那么跟学术硕士有哪些区别?
    【代码源每日一题】序列操作「离线逆序 思维题」
    图解SOC中的Timer(一):系统里有哪些Timer?
    采用springboot 2.7.10来操作clickhouse
    【visionOS】从零开始创建第一个visionOS程序
  • 原文地址:https://blog.csdn.net/qq_1262330535/article/details/127755364