• java计算机毕业设计基于springboo+vue的电影院订票管理系统


    项目介绍

    本论文主要论述了如何使用JAVA语言开发一个影城管理系统 ,本系统将严格按照软件开发流程进行各个阶段的工作,采用B/S架构,面向对象编程思想进行项目开发。在引言中,作者将论述影城管理系统的当前背景以及系统开发的目的,后续章节将严格按照软件开发流程,对系统进行各个阶段分析设计。
    影城管理系统的主要使用者分为管理员和用户,实现功能包括管理员:首页、个人中心、用户管理、电影类型管理、放映厅管理、电影信息管理、购票统计管理、系统管理、订单管理,用户前台:首页、电影信息、电影资讯、个人中心、后台管理、在线客服等功能。由于本网站的功能模块设计比较全面,所以使得整个影城管理系统信息管理的过程得以实现。
    本系统的使用可以实现本影城管理系统管理的信息化,可以方便管理员进行更加方便快捷的管理,可以提高管理人员的工作效率。

    功能介绍

    在这里插入图片描述
    本影城管理系统主要包括二大功能模块,即用户功能模块和管理员功能模块。
    (1)管理员模块:系统中的核心用户是管理员,管理员登录后,通过管理员功能来管理后台系统。主要功能有:首页、个人中心、用户管理、电影类型管理、放映厅管理、电影信息管理、购票统计管理、系统管理、订单管理等功能
    (2)用户前台:首页、电影信息、电影资讯、个人中心、后台管理、在线客服等功能

    开发环境

    java计算机毕业设计基于springboo+vue的电影院订票管理系统
    开发语言:Java+mysql+vue
    开发工具:IDEA /Eclipse
    数据库:MYSQL5.7
    应用服务:Tomcat7/Tomcat8
    使用框架:ssm+vue
    可定制框架:ssm/Springboot/vue/python/PHP/小程序/安卓均可开发

    系统截图

    用户前台功能模块

    影城管理系统 ,在系统首页可以查看首页、电影信息、电影资讯、个人中心、后台管理、在线客服等内容请添加图片描述

    用户登录、用户注册

    在注册页面可以填写用户名、密码、姓名、联系电话等信息进行注册、登录,如图
    在这里插入图片描述

    电影信息

    在电影信息页面通过查看电影名称、电影类型、海报、导演、主演、上映日期、片长、电影预告、放映厅、场次、价格、座位总数等信息进行立即预定、点我收藏,如图5-3所示。在个人中心页面通过填写用户名、密码、姓名、头像、性别、联系电话等信息进行更新信息、退出登录操作
    请添加图片描述
    请添加图片描述

    管理员功能模块

    管理员登录,通过填写用户名、密码、角色进行登录
    管理员登录进入影城管理系统可以查看首页、个人中心、用户管理、电影类型管理、放映厅管理、电影信息管理、购票统计管理、系统管理、订单管理等信息
    请添加图片描述

    用户管理

    在用户管理页面中可以通过填写用户名、姓名、头像、性别、联系电话等内容进行修改、删除,如图5-6所示。还可以根据需要对电影类型管理进行详情,修改或删除等详细操作,如图
    在这里插入图片描述

    电影信息管理

    在电影信息管理页面中可以填写电影名称、电影类型、海报、导演、主演、上映日期、片长、电影预告、放映厅、场次、价格、座位总数、已选座位用号隔开等信息,并可根据需要对已有电影信息管理进行修改或删除等详细操作,如图请添加图片描述

    订单管理

    在订单管理页面中可以查看订单编号、商品名称、商品图片、购买数量、价格/积分、折扣价格、总价格/总积分、折扣总价格、支付类型、状态、地址等内容,并且根据需要对已有订单管理进行详情,修改或删除等详细操作,如图请添加图片描述
    摘 要 I
    1 绪论 1
    1.1研究背景 1
    1.2研究现状 1
    1.3研究内容 2
    2 系统关键技术 3
    2.1 Spring Boot框架 3
    2.2 JAVA技术 3
    2.3 MYSQL数据库 4
    2.4 B/S结构 4
    3 系统分析 5
    3.1 可行性分析 5
    3.1.1 技术可行性 5
    3.1.2经济可行性 5
    3.1.3操作可行性 5
    3.2 系统性能分析 5
    3.3 系统功能分析 6
    3.4系统流程分析 7
    3.4.1登录流程 7
    3.4.2注册流程 8
    3.4.3添加信息流程 8
    3.4.4删除信息流程 9
    4 系统设计 10
    4.1系统概要设计 10
    4.2系统结构设计 10
    4.3系统顺序图设计 11
    4.3.1登录模块顺序图 11
    4.3.2添加信息模块顺序图 11
    4.4数据库设计 12
    4.4.1数据库E-R图设计 12
    4.4.2数据库表设计 13
    第5章 系统详细设计 17
    5.1用户前台功能模块 17
    5.2管理员功能模块 18
    6 系统测试 24
    6.1 测试定义 24
    6.2 测试目的 24
    6.3测试方案 25
    (1)模块测试 25
    (2)集成测试: 25
    (3)验收测试: 25
    6.4系统分析 27
    7 结论 28
    参考文献 29
    谢辞 30

    核心代码

    
    /**
     * 用户
     * 后端接口
     
     */
    @RestController
    @RequestMapping("/yonghu")
    public class YonghuController {
        @Autowired
        private YonghuService yonghuService;
        
    	@Autowired
    	private TokenService tokenService;
    	
    	/**
    	 * 登录
    	 */
    	@IgnoreAuth
    	@RequestMapping(value = "/login")
    	public R login(String username, String password, String captcha, HttpServletRequest request) {
    		YonghuEntity user = yonghuService.selectOne(new EntityWrapper<YonghuEntity>().eq("gerenzhanghao", username));
    		if(user==null || !user.getMima().equals(password)) {
    			return R.error("账号或密码不正确");
    		}
    		
    		String token = tokenService.generateToken(user.getId(), username,"yonghu",  "用户" );
    		return R.ok().put("token", token);
    	}
    	
    	/**
         * 注册
         */
    	@IgnoreAuth
        @RequestMapping("/register")
        public R register(@RequestBody YonghuEntity yonghu){
        	//ValidatorUtils.validateEntity(yonghu);
        	YonghuEntity user = yonghuService.selectOne(new EntityWrapper<YonghuEntity>().eq("gerenzhanghao", yonghu.getGerenzhanghao()));
    		if(user!=null) {
    			return R.error("注册用户已存在");
    		}
    		Long uId = new Date().getTime();
    		yonghu.setId(uId);
            yonghuService.insert(yonghu);
            return R.ok();
        }
    	
    	/**
    	 * 退出
    	 */
    	@RequestMapping("/logout")
    	public R logout(HttpServletRequest request) {
    		request.getSession().invalidate();
    		return R.ok("退出成功");
    	}
    	
    	/**
         * 获取用户的session用户信息
         */
        @RequestMapping("/session")
        public R getCurrUser(HttpServletRequest request){
        	Long id = (Long)request.getSession().getAttribute("userId");
            YonghuEntity user = yonghuService.selectById(id);
            return R.ok().put("data", user);
        }
        
        /**
         * 密码重置
         */
        @IgnoreAuth
    	@RequestMapping(value = "/resetPass")
        public R resetPass(String username, HttpServletRequest request){
        	YonghuEntity user = yonghuService.selectOne(new EntityWrapper<YonghuEntity>().eq("gerenzhanghao", username));
        	if(user==null) {
        		return R.error("账号不存在");
        	}
            user.setMima("123456");
            yonghuService.updateById(user);
            return R.ok("密码已重置为:123456");
        }
    
    
        /**
         * 后端列表
         */
        @RequestMapping("/page")
        public R page(@RequestParam Map<String, Object> params,YonghuEntity yonghu,
    		HttpServletRequest request){
            EntityWrapper<YonghuEntity> ew = new EntityWrapper<YonghuEntity>();
    		PageUtils page = yonghuService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, yonghu), params), params));
    
            return R.ok().put("data", page);
        }
        
        /**
         * 前端列表
         */
        @RequestMapping("/list")
        public R list(@RequestParam Map<String, Object> params,YonghuEntity yonghu, HttpServletRequest request){
            EntityWrapper<YonghuEntity> ew = new EntityWrapper<YonghuEntity>();
    		PageUtils page = yonghuService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, yonghu), params), params));
            return R.ok().put("data", page);
        }
    
    	/**
         * 列表
         */
        @RequestMapping("/lists")
        public R list( YonghuEntity yonghu){
           	EntityWrapper<YonghuEntity> ew = new EntityWrapper<YonghuEntity>();
          	ew.allEq(MPUtil.allEQMapPre( yonghu, "yonghu")); 
            return R.ok().put("data", yonghuService.selectListView(ew));
        }
    
    	 /**
         * 查询
         */
        @RequestMapping("/query")
        public R query(YonghuEntity yonghu){
            EntityWrapper< YonghuEntity> ew = new EntityWrapper< YonghuEntity>();
     		ew.allEq(MPUtil.allEQMapPre( yonghu, "yonghu")); 
    		YonghuView yonghuView =  yonghuService.selectView(ew);
    		return R.ok("查询用户成功").put("data", yonghuView);
        }
    	
        /**
         * 后端详情
         */
        @RequestMapping("/info/{id}")
        public R info(@PathVariable("id") Long id){
            YonghuEntity yonghu = yonghuService.selectById(id);
            return R.ok().put("data", yonghu);
        }
    
        /**
         * 前端详情
         */
        @RequestMapping("/detail/{id}")
        public R detail(@PathVariable("id") Long id){
            YonghuEntity yonghu = yonghuService.selectById(id);
            return R.ok().put("data", yonghu);
        }
        
    
    
    
        /**
         * 后端保存
         */
        @RequestMapping("/save")
        public R save(@RequestBody YonghuEntity yonghu, HttpServletRequest request){
        	yonghu.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
        	//ValidatorUtils.validateEntity(yonghu);
        	YonghuEntity user = yonghuService.selectOne(new EntityWrapper<YonghuEntity>().eq("gerenzhanghao", yonghu.getGerenzhanghao()));
    		if(user!=null) {
    			return R.error("用户已存在");
    		}
    		yonghu.setId(new Date().getTime());
            yonghuService.insert(yonghu);
            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
    • 141
    • 142
    • 143
    • 144
    • 145
    • 146
    • 147
    • 148
    • 149
    • 150
    • 151
    • 152
    • 153
    • 154
    • 155
    • 156
    • 157
    • 158
    • 159
    • 160
    • 161
    • 162
  • 相关阅读:
    NC9 二叉树中和为某一值的路径(一)
    分布式调度xxl-job实战应用解析
    手写一个数字动态滚动加载组件,从0加载到指定数字
    dvwa 文件上传漏洞通关攻略
    GSCoolink GSV2201S DisplayPort 1.4转HDMI 2.0
    java计算机毕业设计瀚绅睿茨二人二轮车租赁管理源码+mysql数据库+系统+lw文档+部署
    【JDBC】------ResultSet(结果集)和常见异常
    LeetCode第81场双周赛
    三十七、【进阶】SQL的explain
    k8s的pod调度之节点选择器
  • 原文地址:https://blog.csdn.net/z459382737/article/details/126394920