✌全网粉丝20W+,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌
🍅文末获取项目下载方式🍅
一、项目背景介绍:
随着社会的发展和人们生活水平的提高,房屋租赁市场的需求逐渐增加。为了满足人们对于方便、快捷的房屋租赁服务的需求,我们决定开发一款基于JAVA+SSM前后端分离的房屋租赁系统。
我们的目标是为游客、房东和租客提供一个便捷、高效的房屋租赁平台,使其能够方便地找到适合自己需求的房源并进行租赁操作。通过该系统,游客可以浏览系统主页,搜索房源信息,并查看房源详情。房东可以注册成为系统用户,发布自己的房源信息,并管理订单、反馈信息和收藏信息等。租客也可以注册成为系统用户,搜索、预订房源,并进行相关的订单管理、反馈信息和收藏管理等操作。
在研发过程中,我们将使用JAVA作为后端开发语言,并采用SSM框架实现前后端分离。这种架构能够使系统的开发更加模块化和可扩展,同时也提供了良好的安全性和稳定性。
为了保证系统的功能完善和用户体验,我们将注意以下几个方面的设计:
系统共设计了三个角色:游客、房东、租客。当时考虑的比较简单,没有设置系统管理员的角色,反正对于一些小项目而且也够用了。
- 游客:尚未进行注册和登录。具备登录注册、房源的搜索、查询详情等权限。
- 房东:用户角色为房东,有出租房屋需求的群体。具备登录、个人资料的修改、登录密码修改、房源的搜索、查询详情、房源的收藏、查看租房订单、取消订单、房源信息的发布、房源信息的查询管理、房源状态的管理、反馈信息的处理等权限。
- 租客:用户角色为租客,有租房需求的群体。具备登录、个人资料的修改、登录密码修改、房源的搜索、查询详情、房源的收藏、创建租房订单、取消订单、删除订单、支付、房源评价、反馈信息的填报等权限。
二、项目技术简介:
前端
名称 | 描述 |
---|---|
HTML、CSS | 用于设计网页的内容和样式 |
JavaScript、JQuery | 作为开发 Web 页面的脚本语言,为网页添加各式各样的动态功能,为用户提供更流畅美观的浏览效果 |
Bootstrap | 基于 HTML、CSS、JavaScript 开发的简洁、直观、强悍的前端开发框架,使得 Web 开发更加快捷 |
后端
名称 | 描述 |
---|---|
Spring | Spring 是 Java EE 编程领域的一个轻量级开源框架,该框架由一个叫 Rod Johnson 的程序员在 2002 年最早提出并随后创建,是为了解决企业级编程开发中的复杂性,实现敏捷开发的应用型框架。Spring 是一个开源容器框架,它集成各类型的工具,通过核心的 Bean factory 实现了底层的类的实例化和生命周期的管理。在整个框架中,各类型的功能被抽象成一个个的 Bean,这样就可以实现各种功能的管理,包括动态加载和切面编程。 |
SpringMVC | Spring MVC 属于 SpringFrameWork 的后续产品,已经融合在 Spring Web Flow 里面。Spring 框架提供了构建 Web 应用程序的全功能 MVC 模块。 |
MyBatis Plus | MyBatis-Plus(简称 MP)是一个 MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。 |
Thymeleaf | Thymeleaf 是一个流行的模板引擎,该模板引擎采用 Java 语言开发的,用于渲染 XML/XHTML/HTML5 内容的模板引擎。类似 JSP、Velocity、FreeMaker 等,它也可以轻易的与 Spring MVC 等 Web 框架进行集成作为 Web 应用的模板引擎。 |
Druid | Druid 是一个高效的数据查询系统,主要解决的是对于大量的基于时序的数据进行聚合查询。数据可以实时摄入,进入到 Druid 后立即可查,同时数据是几乎是不可变。通常是基于时序的事实事件,事实发生后进入 Druid,外部系统就可以对该事实进行查询。 |
三、系统功能模块介绍:
四、数据库设计:
1:comment(comment)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | int | NULL | 主键ID |
reply_id | int | NULL | 回复评论ID |
room_id | int | NULL | 房间ID |
user_id | int | NULL | 用户ID |
content | text | NULL | 内容 |
rate_count | int | NULL | 评价星数 |
create_time | datetime | NULL | 创建时间 |
update_time | datetime | NULL | 修改时间 |
2:favor(favor)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | int | NULL | 主键ID |
user_id | int | NULL | 用户ID |
room_id | int | NULL | 房子ID |
create_time | datetime | NULL | 创建时间 |
update_time | datetime | NULL | 修改时间 |
3:message(message)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | int | NULL | 主键ID |
room_id | int | NULL | 房子ID |
order_id | int | NULL | |
send_id | int | NULL | 发送人ID |
accept_id | int | NULL | 接受人ID |
title | varchar | NULL | 标题 |
content | text | NULL | 内容 |
status | varchar | NULL | 状态 |
create_time | datetime | NULL | 创建时间 |
update_time | datetime | NULL | 修改时间 |
remark | varchar | NULL | 处理意见 |
4:room(room)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | int | NULL | 主键ID |
owner_id | int | NULL | 房东ID |
title | varchar | NULL | 标题 |
sub_title | varchar | NULL | 副标题 |
month_price | double | NULL | 月租价格 |
location | varchar | NULL | 所在地 |
info | text | NULL | 描述 |
content | text | NULL | 内容 |
img | text | NULL | 封面 |
images | text | NULL | 图片 |
create_time | datetime | NULL | 创建时间 |
update_time | datetime | NULL | 修改时间 |
look_count | int | NULL | 浏览量 |
5:room_detail(room_detail)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | int | NULL | 主键ID |
room_id | int | NULL | 房间ID |
bedroom_count | int | NULL | 房间数量 |
parlour_count | int | NULL | 客厅数量 |
restroom_count | int | NULL | 卫生间数量 |
bathroom_count | int | NULL | 浴室数量 |
capacity | varchar | NULL | 大小 |
garage | int | NULL | 车库数量 |
area | varchar | NULL | 小区 |
address | varchar | NULL | 详细地址 |
type | varchar | NULL | 类型 |
build_year | varchar | NULL | 建造年限 |
status | varchar | NULL | 状态 |
elevator | varchar | NULL | 是否有电梯 |
kitchen | varchar | NULL | 是否有厨房 |
free_wifi | varchar | NULL | 免费Wi-Fi |
window | varchar | NULL | 窗户 |
metro | varchar | NULL | 是否有地铁 |
rent_type | varchar | NULL | 租赁方式 |
create_time | datetime | NULL | 创建时间 |
update_time | datetime | NULL | 修改时间 |
6:room_order(room_order)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | int | NULL | 主键ID |
room_id | int | NULL | 房子ID |
user_id | int | NULL | 用户ID |
owner_id | int | NULL | 房东ID |
order_num | varchar | NULL | 订单编号 |
pay_order | varchar | NULL | 订单流水号 |
title | varchar | NULL | 标题 |
sub_title | varchar | NULL | 副标题 |
pay_money | double | NULL | 价格 |
content | text | NULL | 内容 |
attachment | varchar | NULL | 附件文件 |
status | varchar | NULL | 状态 |
create_time | datetime | NULL | 创建时间 |
pay_time | datetime | NULL | 支付时间 |
update_time | datetime | NULL | 修改时间 |
from_time | datetime | NULL | |
to_time | datetime | NULL |
7:user(user)
字段名 | 类型 | 默认值 | 列注释 |
---|---|---|---|
id | int | NULL | 主键ID |
name | varchar | NULL | 姓名 |
password | varchar | NULL | 登陆密码 |
sex | varchar | NULL | 性别 |
birth | varchar | NULL | 出生年月 |
idcard_num | varchar | NULL | 身份证号码 |
phone | varchar | NULL | 手机号 |
varchar | NULL | 邮箱 | |
location | varchar | NULL | 所在地 |
about | varchar | NULL | 关于 |
role | varchar | NULL | 角色 |
create_time | datetime | NULL | 创建时间 |
update_time | datetime | NULL | 修改时间 |
五、角色介绍:
-
系统共设计了三个角色:游客、房东、租客。当时考虑的比较简单,没有设置系统管理员的角色,反正对于一些小项目而且也够用了。
- 游客:尚未进行注册和登录。具备登录注册、房源的搜索、查询详情等权限。
- 房东:用户角色为房东,有出租房屋需求的群体。具备登录、个人资料的修改、登录密码修改、房源的搜索、查询详情、房源的收藏、查看租房订单、取消订单、房源信息的发布、房源信息的查询管理、房源状态的管理、反馈信息的处理等权限。
- 租客:用户角色为租客,有租房需求的群体。具备登录、个人资料的修改、登录密码修改、房源的搜索、查询详情、房源的收藏、创建租房订单、取消订单、删除订单、支付、房源评价、反馈信息的填报等权限。
六、功能介绍:
游客功能介绍
功能模块 | 功能描述 |
---|---|
登录注册方面 | 注册成为系统用户 |
系统主页 | 浏览系统主页、房源信息搜索、房源详情的查看(统计浏览量) |
房东功能介绍
功能模块 | 功能描述 |
---|---|
登录注册方面 | 填写用户信息进行账号注册、使用邮箱密码进行登录 |
个人资料方面 | 修改个人资料(姓名、所在地、邮箱、手机号、身份证号、个人说明等)、修改登录密码 |
订单管理方面 | 查看所有订单、订单详情、取消订单、删除订单 |
发布房源 | 填写基本信息、填写详细信息、上传封面图片以及房屋照片 |
房源信息管理 | 自己已发布的房源信息、编辑房源、删除房源、暂停发布、启动发布、租期到期 |
反馈信息方面 | 查询所有反馈信息、反馈信息搜索、删除反馈、处理反馈 |
收藏管理方面 | 查询所有收藏信息、收藏信息搜索、取消收藏 |
系统主页 | 浏览系统主页、房源信息搜索、房源详情的查看(统计浏览量)、收藏房源 |
租客功能介绍
功能模块 | 功能描述 |
---|---|
登录注册方面 | 填写用户信息进行账号注册、使用邮箱密码进行登录 |
个人资料方面 | 修改个人资料(姓名、所在地、邮箱、手机号、身份证号、个人说明等)、修改登录密码 |
订单管理方面 | 查看所有订单、创建订单、支付订单(假支付)、订单详情、取消订单、删除订单、评论房源 |
反馈信息方面 | 反馈信息、查询所有反馈信息、反馈信息搜索、查询详情以及处理意见 |
收藏管理方面 | 查询所有收藏信息、收藏信息搜索、取消收藏 |
系统主页 | 浏览系统主页、房源信息搜索、房源详情的查看(统计浏览量)、收藏房源 |
七、开发工具与环境:
-
开发工具
- IntelliJ IDEA 2019.2.2 主要进行系统的开发、系统调试等
- WebStorm 2019.2.1 主要进行前端页面的开发。
- Navcat 主要进行数据库的连接、建库建表、系统调试等。
-
开发环境
- JDK 1.8
- Maven 3.6
- MySQL 5.7
- Tomcat 8.5.78
八、项目结构:
本项目使用标准 SSM 目录结构,后端使用 MVC 三层架构,具体项目结构如下:
- src:源码目录
- src/main/java:源码主体目录
- src/main/java/xxx/component:java常用组件存放地址,比如登录拦截器【拦截器】
- src/main/java/xxx/controller:java控制器类存放地址【控制层】
- src/main/java/xxx/entity:java实体类存放地址【模型】
- src/main/java/xxx/dao:MyBatis的映射接口存放地址,【数据访问层】
- src/main/java/xxx/service:java业务层接口存放地址【业务逻辑抽象层】
- src/main/java/xxx/utils:java工具类存放地址【工具类】
- src/resources:资源文件存放目录(Spring、SpringMVC、Mybatis、日志、数据源、数据库脚本等)
- src/main/resources/mybatis:MyBatis配置文件位置
- src/main/resources/mybatis/mybatis-config.xml:MyBatis全局配置文件
- src/main/resources/spring/applicationContext.xml:Spring配置文件
- src/main/resources/springmvc/springmvc-servlet.xml:Spring配置文件
- src/main/resources/db.properties:数据源配置
- src/main/resources/log4j.properties:日志配置
- src/main/resources/verio_house.sql:数据库脚本
- src/main/webapp/resource:前端静态资源存放地址
- src/main/webapp/WEB-INF/templates:前端页面存放地址
- src/main/webapp/WEB-INF/web.xml:Java EE工程文件
- pom.xml:Maven项目依赖管理文件
注意!如果想要部署本项目,你需要修改两个文件:
- 数据库配置文件:src/main/resources/db.properties
- 阿里云对象存储配置:src/main/java/com/verio/utils/OssUtil.java
注意 MySQL 的版本是 5.7,使用其它版本可能会出现其它未知问题。
九、代码示例:
/**
生成验证码
*/
@GetMapping("/captchaImage")
public AjaxResult getCode(HttpServletResponse response) throws IOException
{
AjaxResult ajax = AjaxResult.success();
boolean captchaEnabled = configService.selectCaptchaEnabled();
ajax.put("captchaEnabled", captchaEnabled);
if (!captchaEnabled)
{
return ajax;
}
// 保存验证码信息
String uuid = IdUtils.simpleUUID();
String verifyKey = CacheConstants.CAPTCHA_CODE_KEY + uuid;
String capStr = null, code = null;
BufferedImage image = null;
// 生成验证码
String captchaType = RuoYiConfig.getCaptchaType();
if ("math".equals(captchaType))
{
String capText = captchaProducerMath.createText();
capStr = capText.substring(0, capText.lastIndexOf("@"));
code = capText.substring(capText.lastIndexOf("@") + 1);
image = captchaProducerMath.createImage(capStr);
}
else if ("char".equals(captchaType))
{
capStr = code = captchaProducer.createText();
image = captchaProducer.createImage(capStr);
}
redisCache.setCacheObject(verifyKey, code, Constants.CAPTCHA_EXPIRATION, TimeUnit.MINUTES);
// 转换流信息写出
FastByteArrayOutputStream os = new FastByteArrayOutputStream();
try
{
ImageIO.write(image, "jpg", os);
}
catch (IOException e)
{
return AjaxResult.error(e.getMessage());
}
ajax.put("uuid", uuid);
ajax.put("img", Base64.encode(os.toByteArray()));
return ajax;
}
/**
通用的本地文件上传
@param multipartFile 文件对象
@return 文件访问链接URL
/
@PostMapping("/file")
public SimpleResponse uploadImg(@RequestParam("file") MultipartFile file) {
// 文件后缀
String suffix = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".") + 1);
File savePathFile = new File(newTomcatFolder);
if (!savePathFile.exists()) {
// 若不存在该目录,则创建目录
savePathFile.mkdir();
}
// 通过UUID生成唯一文件名
String filename = UUID.randomUUID() + "." + suffix;
try {
// 将文件保存指定目录
file.transferTo(new File(newTomcatFolder + filename));
} catch (Exception e) {
e.printStackTrace();
return SimpleResponse.error("保存文件异常");
}
// 返回访问链接
return SimpleResponse.success(newTomcatHost + filename);
}
/*
用户登录
*/
@PostMapping("/login")
public ReturnMsg manageLogin(@RequestBody Map<String, String> param) {
if (StrUtil.isEmpty(param.get("username")) || StrUtil.isEmpty(param.get("password"))) {
return ReturnMsg.error("用户名或密码错误!");
}
ManageDTO manageDTO = new ManageDTO();
manageDTO.setUserName(param.get("username"));
manageDTO.setPassWord(param.get("password"));
QueryWrapper manageDTOQueryWrapper = new QueryWrapper<>(manageDTO);
manageDTOQueryWrapper.last("limit 1");
ManageDTO adminDTOS = manageService.getOne(manageDTOQueryWrapper);
if (adminDTOS == null) return ReturnMsg.error("用户名或密码错误!");
Map<String, Object> map = new HashMap<>();
map.put("avatar", StrUtil.isNotBlank(adminDTOS.getPhotoImg()) ? adminDTOS.getPhotoImg() : "https://wpimg.wallstcn.com/f778738c-e4f8-4870-b634-56703b4acafe.gif");
map.put("introduction", adminDTOS.getName() + ",你好!");
map.put("name", adminDTOS.getName());
map.put("roles", Arrays.asList("admin"));
map.put("type", adminDTOS.getStatus());
Map<String, String> returnMap = new HashMap<>();
String uuid = UUID.randomUUID().toString();
returnMap.put("token", uuid);
userInfoMap.put(uuid, JSON.toJSONString(map));
return ReturnMsg.ok(returnMap);
}
十、系统截图:
十一、项目总结:
基于JAVA+SSM的房屋租赁系统的整体功能模块的实现,主要是对自己在大学这几年时间所学内容的一个测试,对于系统,主要是通过现在智能化的基于JAVA+SSM的房屋租赁系统进行开始系统的实现,经过一个学期的毕业设计的实现完成已接近尾声,到目前为止,当我回想起整个学期的系统开发日,收获颇丰。毕业设计的主要任务是建立一个智能化的基于JAVA+SSM的房屋租赁系统 ,主要使用JAVA和Mysql数据库的开发工具,对系统的每个功能模块进行相对应的操作,最后,系统调试结果表明系统基本可以满足功能要求。
基于JAVA+SSM的房屋租赁系统平台的开发对我大学学习的改进有很大帮助。它使我能够学习计算机知识的相关技术方面问题及与人交往的沟通交流方面,让我意识到无论我们做什么,我们都需要坚持不懈,努力工作,只有这样尝试了并且坚持去做了,我们才可以成功,才可以获得成功的喜悦,如果没有尝试,知识想,那连成功的机会都没有,实际操作进行做了,才会越来越近的靠近成功,随着道路一路向前,未来的路是美好的。对于驾校管理平台的实现,是自己第一次完成的设计一个管理系统。在项目的设计过程中,我克服了各种困难,并且在面对这些困难,我积极的面对,想办法解决问题,并且更好的掌握了理论知识和动手操作实践能力,从系统的开发到设计完成,我完成了一个更全面、更完善、更安全的平台管理系统,这也让我取得了很大的成就感,也使我对未来的生活更有信心。
十二、源码获取:
大家点赞、收藏、关注、评论啦 、查看👇🏻👇🏻👇🏻获取项目下载链接,博主联系方式👇🏻👇🏻👇🏻
链接点击直达:下载链接