ssm基于java的酒店客房预定管理系统(源码+文档+调试+vue+前后端分离)

收藏关注不迷路!!

🌟文末获取源码+数据库🌟

感兴趣的可以先收藏起来,还有大家在毕设选题(免费咨询指导选题),项目以及论文编写等相关问题都可以给我留言咨询,希望帮助更多的人


前言

首先,论文一开始便是清楚的论述了系统的研究内容。其次,剖析系统需求分析,弄明白“做什么”,分析包括业务分析和业务流程的分析以及用例分析,更进一步明确系统的需求。然后在明白了系统的需求基础上需要进一步地设计系统,主要包罗软件架构模式、整体功能模块、数据库设计。本项目软件架构选择B/S模式,总体功能模块运用自顶向下的分层思想。再然后就是实现系统并进行代码编写实现功能。论文的最后章节总结一下自己完成本论文和开发本项目的心得和总结。通过酒店客房预定管理系统将会使酒店客房预定各个方面的工作效率带来实质性的提升。

详细视频演示

文章底部名片,联系我看更详细的演示视频

一、项目介绍

开发语言:Java
框架:ssm
JDK版本:JDK1.8
服务器:tomcat7
数据库:mysql
数据库工具:Navicat11
开发软件:eclipse/myeclipse/idea
Maven包:Maven

————————————————

二、功能介绍

考虑到实际生活中酒店客房预定管理系统方面的需要以及对该平台认真的分析,将系统权限按管理员和用户这两类涉及用户划分。
(a) 管理员;管理员使用本系统涉到的功能主要有:个人中心,用户管理,客房类型管理,酒店客房管理,客房预定管理,开房记录管理,退房结账管理,系统管理等功能。
在这里插入图片描述

三、核心代码

部分代码:


package com.example.controller;

import cn.hutool.core.util.StrUtil;
import cn.hutool.crypto.SecureUtil;
import com.example.common.Result;
import com.example.common.ResultCode;
import com.example.entity.Caiwu;
import com.example.exception.CustomException;
import com.example.service.CaiwuService;
import com.example.utils.MapWrapperUtils;
import com.example.utils.jwt.JwtUtil;
import com.example.vo.CaiwuVo;
import org.springframework.beans.BeanUtils;
import org.springframework.web.bind.annotation.*;

import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

@RestController
@RequestMapping(value = "/caiwu")
public class CaiwuController {

    @Resource
    private CaiwuService caiwuService;

    @PostMapping
    public Result<Caiwu> add(@RequestBody CaiwuVo caiwu) {
        caiwuService.add(caiwu);
           return Result.success(caiwu);
    }
	
	

    @PostMapping("/deleteList")
    public Result<Caiwu> deleteList(@RequestBody CaiwuVo caiwu) {
        caiwuService.deleteList(caiwu.getList());
        return Result.success();
    }

    @DeleteMapping("/{id}")
    public Result delete(@PathVariable Long id) {
        caiwuService.delete(id);
        return Result.success();
    }

    @PutMapping
    public Result update(@RequestBody CaiwuVo caiwu) {
        caiwuService.update(caiwu);
        return Result.success();
    }

    @GetMapping("/{id}")
    public Result<Caiwu> detail(@PathVariable Integer id) {
        Caiwu caiwu = caiwuService.findById(id);
        return Result.success(caiwu);
    }

    @GetMapping
    public Result<List<Caiwu>> all() {
        return Result.success(caiwuService.list());
    }

    @PostMapping("/page")
    public Result<CaiwuVo> page(@RequestBody CaiwuVo caiwuVo) {
        return Result.success(caiwuService.findPage(caiwuVo));
    }
	    @PostMapping("/login")
    public Result login(@RequestBody Caiwu caiwu, HttpServletRequest request) {
        if (StrUtil.isBlank(caiwu.getZhanghao()) || StrUtil.isBlank(caiwu.getMima())) {
            throw new CustomException(ResultCode.PARAM_LOST_ERROR);
        }
        Caiwu login = caiwuService.login(caiwu);
//        if(!login.getStatus()){
//            return Result.error("1001","状态限制,无法登录系统");
//        }
        if(login != null) {
            HashMap hashMap = new HashMap();
            hashMap.put("user", login);
            Map<String, Object> map = MapWrapperUtils.builder(MapWrapperUtils.KEY_USER_ID,caiwu.getId());
            String token = JwtUtil.creatToken(map);
            hashMap.put("token", token);
            return Result.success(hashMap);
        }else {
            return Result.error();
        }
    }
    @PutMapping("/updatePassword")
    public Result updatePassword(@RequestBody Caiwu info, HttpServletRequest request) {
        Caiwu caiwu = caiwuService.findById(info.getId());
        String oldPassword = SecureUtil.md5(info.getMima());
        if (!oldPassword.equals(caiwu.getMima())) {
            return Result.error(ResultCode.PARAM_PASSWORD_ERROR.code, ResultCode.PARAM_PASSWORD_ERROR.msg);
        }
        info.setMima(SecureUtil.md5(info.getNewPassword()));
        Caiwu caiwu1 = new Caiwu();
        BeanUtils.copyProperties(info, caiwu1);
        caiwuService.update(caiwu1);
        return Result.success();
    }
}

数据库参考


--
-- Current Database: `jspmi59uz`
--

/*!40000 DROP DATABASE IF EXISTS `jspmi59uz`*/;

CREATE DATABASE /*!32312 IF NOT EXISTS*/ `jspmi59uz` /*!40100 DEFAULT CHARACTER SET utf8mb4 */;

USE `jspmi59uz`;

--
-- Table structure for table `config`
--

DROP TABLE IF EXISTS `config`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `config` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `name` varchar(100) NOT NULL COMMENT '配置参数名称',
  `value` varchar(100) DEFAULT NULL COMMENT '配置参数值',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 COMMENT='配置文件';
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `config`
--

LOCK TABLES `config` WRITE;
/*!40000 ALTER TABLE `config` DISABLE KEYS */;
INSERT INTO `config` VALUES (1,'picture1','upload/picture1.jpg'),(2,'picture2','upload/picture2.jpg'),(3,'picture3','upload/picture3.jpg');
/*!40000 ALTER TABLE `config` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `discussjiudiankefang`
--

DROP TABLE IF EXISTS `discussjiudiankefang`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `discussjiudiankefang` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `refid` bigint(20) NOT NULL COMMENT '关联表id',
  `userid` bigint(20) NOT NULL COMMENT '用户id',
  `nickname` varchar(200) DEFAULT NULL COMMENT '用户名',
  `content` longtext NOT NULL COMMENT '评论内容',
  `reply` longtext COMMENT '回复内容',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=97 DEFAULT CHARSET=utf8 COMMENT='酒店客房评论表';
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `discussjiudiankefang`
--

LOCK TABLES `discussjiudiankefang` WRITE;
/*!40000 ALTER TABLE `discussjiudiankefang` DISABLE KEYS */;
INSERT INTO `discussjiudiankefang` VALUES (91,'2022-04-25 06:56:09',1,1,'用户名1','评论内容1','回复内容1'),(92,'2022-04-25 06:56:09',2,2,'用户名2','评论内容2','回复内容2'),(93,'2022-04-25 06:56:09',3,3,'用户名3','评论内容3','回复内容3'),(94,'2022-04-25 06:56:09',4,4,'用户名4','评论内容4','回复内容4'),(95,'2022-04-25 06:56:09',5,5,'用户名5','评论内容5','回复内容5'),(96,'2022-04-25 06:56:09',6,6,'用户名6','评论内容6','回复内容6');
/*!40000 ALTER TABLE `discussjiudiankefang` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `jiudiankefang`
--

DROP TABLE IF EXISTS `jiudiankefang`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `jiudiankefang` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `fangjianhao` varchar(200) NOT NULL COMMENT '房间号',
  `kefangleixing` varchar(200) DEFAULT NULL COMMENT '客房类型',
  `kefangmingcheng` varchar(200) DEFAULT NULL COMMENT '客房名称',
  `kefangsheshi` varchar(200) DEFAULT NULL COMMENT '客房设施',
  `kefangjiage` int(11) NOT NULL COMMENT '客房价格',
  `dingjin` float NOT NULL COMMENT '定金',
  `kefangjieshao` longtext COMMENT '客房介绍',
  `kefangtupian` varchar(200) DEFAULT NULL COMMENT '客房图片',
  `kefangzhuangtai` varchar(200) DEFAULT NULL COMMENT '客房状态',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=37 DEFAULT CHARSET=utf8 COMMENT='酒店客房';
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `jiudiankefang`
--

LOCK TABLES `jiudiankefang` WRITE;
/*!40000 ALTER TABLE `jiudiankefang` DISABLE KEYS */;
INSERT INTO `jiudiankefang` VALUES (31,'2022-04-25 06:56:09','房间号1','客房类型1','客房名称1','客房设施1',1,1,'客房介绍1','upload/jiudiankefang_kefangtupian1.jpg','已预约'),(32,'2022-04-25 06:56:09','房间号2','客房类型2','客房名称2','客房设施2',2,2,'客房介绍2','upload/jiudiankefang_kefangtupian2.jpg','已预约'),(33,'2022-04-25 06:56:09','房间号3','客房类型3','客房名称3','客房设施3',3,3,'客房介绍3','upload/jiudiankefang_kefangtupian3.jpg','已预约'),(34,'2022-04-25 06:56:09','房间号4','客房类型4','客房名称4','客房设施4',4,4,'客房介绍4','upload/jiudiankefang_kefangtupian4.jpg','已预约'),(35,'2022-04-25 06:56:09','房间号5','客房类型5','客房名称5','客房设施5',5,5,'客房介绍5','upload/jiudiankefang_kefangtupian5.jpg','已预约'),(36,'2022-04-25 06:56:09','房间号6','客房类型6','客房名称6','客房设施6',6,6,'客房介绍6','upload/jiudiankefang_kefangtupian6.jpg','已预约');
/*!40000 ALTER TABLE `jiudiankefang` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `kaifangjilu`
--

DROP TABLE IF EXISTS `kaifangjilu`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `kaifangjilu` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `fangjianhao` varchar(200) DEFAULT NULL COMMENT '房间号',
  `kefangleixing` varchar(200) DEFAULT NULL COMMENT '客房类型',
  `kefangmingcheng` varchar(200) DEFAULT NULL COMMENT '客房名称',
  `kefangjiage` varchar(200) DEFAULT NULL COMMENT '客房价格',
  `dingjin` varchar(200) DEFAULT NULL COMMENT '定金',
  `yudingshijian` varchar(200) DEFAULT NULL COMMENT '预定时间',
  `yonghuzhanghao` varchar(200) DEFAULT NULL COMMENT '用户账号',
  `yonghuxingming` varchar(200) DEFAULT NULL COMMENT '用户姓名',
  `yonghushouji` varchar(200) DEFAULT NULL COMMENT '用户手机',
  `shenfenzheng` varchar(200) DEFAULT NULL COMMENT '身份证',
  `kaifangshijian` datetime DEFAULT NULL COMMENT '开房时间',
  `tuifangzhuangtai` varchar(200) NOT NULL COMMENT '退房状态',
  `crossuserid` bigint(20) DEFAULT NULL COMMENT '跨表用户id',
  `crossrefid` bigint(20) DEFAULT NULL COMMENT '跨表主键id',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=57 DEFAULT CHARSET=utf8 COMMENT='开房记录';
/*!40101 SET character_set_client = @saved_cs_client */;


四、效果图

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

五、文章目录

目录
1绪论 4
1.1项目研究的背景 4
1.2开发意义 4
1.3课题研究现状 4
1.4项目研究内容与结构 5
2开发技术介绍 6
2.1B/S架构 6
2.2Java技术 6
2.3MySQL 介绍 6
2.4MySQL环境配置 7
2.5JSP技术介绍 7
3系统分析 8
3.1可行性分析 8
3.1.1技术可行性 8
3.1.2经济可行性 8
3.1.3操作可行性 8
3.1.4 运行可行性 9
3.2系统性能需求分析 9
3.3系统功能分析 9
3.4系统流程的分析 10
3.4.1 用户管理的流程 11
3.4.2个人中心管理流程 11
3.4.3登录流程 12
4系统设计 13
4.1 软件功能模块设计 13
4.2数据库设计与实现 13
4.2.1概念模型设计 13
4.2.2物理模型设计 14
5系统详细设计 21
5.1系统功能模块 21
5.2管理员模块 22
5.3用户功能模块 27
6系统测试 29
7总结与心得体会 30
7.1 总结 30
7.2 心得体会 30
参考文献 31
致谢 32

六 、源码获取

下方名片联系我即可!!


大家点赞、收藏、关注、评论啦 、查看👇🏻获取联系方式👇🏻

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

毕业程序员

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值