房屋租赁管理系统
-
- 一、功能描述
- 二、选题背景意义
- 三、系统设计思路
- 四、系统详情截图
-
- 1、用户对房屋租赁模块实现
- 2、房屋管理员对房屋管理功能模块
- 3、房屋管理人员对租赁订单管理功能模块
- 五、其他截图
- 六、论文
一、功能描述
本系统为基于jsp+ssm+mysql的房租出租网,功能如下:
前台网页:查看并搜索所有的房屋情况,登录、注册、预约房租、用户可以在个人中心查看我的订单、我的资料、需改密码。
后台管理:系统设置、用户管理、系统日志、房屋管理、用户管理、租赁管理。
系统功能完整,使用目前主流框架ssm,适合作为毕业设计、课程设计、数据库大作业。
二、选题背景意义
随着我国市场经济的快速发展和人们生活水平的不断提高,简单的房屋出租服务已经不能满足人们的需求。如何利用先进的管理手段,提高房屋出租的管理水平,是当今社会所面临的一个重要课题。
本文采用结构化分析的方法,详细阐述了一个功能比较强大的中信房屋出租管理系统的前后台开发、操作流程和涉及的一些关键技术。首先进行了可行性分析,然后是系统分析,通过实际的业务流程调研,分析业务流程和系统的组织结构,完成了数据流分析和数据字典;然后是系统设计阶段主要完成了功能模块的划分、阐述了系统设计的思想、数据库的设计和系统设计的工具及技术。该阶段对本系统各个模块的功能进行了详细设计,形成了本系统的功能模块图;数据库设计时先进行了概念结构设计,然后进行了逻辑结构设计,最后完成了数据表的设计。
目前在本课题范围内,分析了房屋出租管理人员对房屋的管理现状和现有的用户对房屋管理人员的服务的要求。针对两者的要求,设计了一套基于SpringMVC的公寓出租管理系统。本系统的集成开发环境是Eclipse,使用MySQL作为数据库管理系统,Web服务器采用Tomcat,运用SpringMVC及Spring3.0框架技术实现。为了充分利用网络信息化的优势,本系统采用B/S结构。系统具有专门的供用户使用的前台和专门供公寓出租管理人员使用的后台。
在房屋出租管理系统的实现下,网站管理人员能够充分发挥信息化处理的优势,提高日常管理的处理速率。用户一方可以更好的享受信息化处理带来的便利。系统运行能够稳定且高效。并且人机友好程度能够显著提升。
三、系统设计思路
根据需求调研结果确定本系统主要包括以下功能模块
1、房屋管理人员可以通过管理用户信息用例对用户信息进行维护,包括对用户信息的增删改查。管理用户信息用例图如图2.6所示。
2、房屋管理人员可以通过管理房屋信息用例对房屋信息进行维护,包括对房屋信息的增删改查。管理房屋信息用例图如图2.7所示。
3、房屋管理人员可以通过管理租赁信息用例对租赁信息进行维护,包括对租赁信息的增删改查。管理租赁信息用例图如图2.8所示。
四、系统详情截图
1、用户对房屋租赁模块实现
用户对房屋进行租赁操作,采用 Ajax发送异步请求将租赁信息发送到控制层,控制层发送数据到业务逻辑层,业务逻辑层通过调用 DAO层来访问数据库从而执行插入并返回结果。
该模块控制层主要代码:
@RequestMapping(value="/book_order",method=RequestMethod.POST)
@ResponseBody
public Map<String,String> bookOrderAct(BookOrder bookOrder,HttpServletRequest request){
Map<String, String> ret = new HashMap<String, String>();
if(bookOrder == null){
ret.put("type", "error");
ret.put("msg", "请填写正确的出租订单信息!");
return ret;
}
Account account = (Account)request.getSession().getAttribute("account");
if(account == null){
ret.put("type", "error");
ret.put("msg", "客户不能为空!");
return ret;
}
bookOrder.setAccountId(account.getId());
if(bookOrder.getRoomTypeId() == null){
ret.put("type", "error");
ret.put("msg", "房屋不能为空!");
return ret;
}
if(StringUtils.isEmpty(bookOrder.getName())){
ret.put("type", "error");
ret.put("msg", "出租订单联系人名称不能为空!");
return ret;
}
if(StringUtils.isEmpty(bookOrder.getMobile())){
ret.put("type", "error");
ret.put("msg", "出租订单联系人手机号不能为空!");
return ret;
}
if(StringUtils.isEmpty(bookOrder.getIdCard())){
ret.put("type", "error");
ret.put("msg", "联系人身份证号不能为空!");
return ret;
}
if(StringUtils.isEmpty(bookOrder.getArriveDate())){
ret.put("type", "error");
ret.put("msg", "租赁时间不能为空!");
return ret;
}
if(StringUtils.isEmpty(bookOrder.getLeaveDate())){
ret.put("type", "error");
ret.put("msg", "结算时间不能为空!");
return ret;
}
bookOrder.setCreateTime(new Date());
bookOrder.setStatus(0);
if(bookOrderService.add(bookOrder) <= 0){
ret.put("type", "error");
ret.put("msg", "添加失败,请联系管理员!");
return ret;
}
RoomType roomType = roomTypeService.find(bookOrder.getRoomTypeId());
//出租成功后去修改该房屋的出租数
if(roomType != null){
roomType.setBookNum(roomType.getBookNum() + 1);
roomType.setAvilableNum(roomType.getAvilableNum() - 1);
roomTypeService.updateNum(roomType);
//如果可用的房间数为0,则设置该房屋状态已租赁
if(roomType.getAvilableNum() == 0){
roomType.setStatus(0);
roomTypeService.edit(roomType);
}
}
ret.put("type", "success");
ret.put("msg", "出租成功!");
return ret;
}
2、房屋管理员对房屋管理功能模块
房屋管理人员对房屋的基本信息进行增删改查操作,采用Ajax发送异步请求将房屋信息发送到控制层,控制层发送数据到业务逻辑层,业务逻辑层通过调用 DAO层来访问数据库从而执行更改并返回结果。
该模块控制层主要代码:
@RequestMapping(value="/add",method=RequestMethod.POST)
@ResponseBody
public Map<String, String> add(RoomType roomType){
Map<String, String> ret = new HashMap<String, String>();
if(roomType == null){
ret.put("type", "error");
ret.put("msg", "请填写正确的房屋类型信息!");
return ret;
}
if(StringUtils.isEmpty(roomType.getName())){
ret.put("type", "error");
ret.put("msg", "房屋类型名称不能为空!");
return ret;
}
roomType.setAvilableNum(roomType.getRoomNum());//默认房屋数等于可用房屋数
roomType.setBookNum(0);//设置租赁数0
roomType.setLivedNum(0);//设置已租赁数0
if(roomTypeService.add(roomType) <= 0){
ret.put("type", "error");
ret.put("msg", "添加失败,请联系管理员!");
return ret;
}
ret.put("type", "success");
ret.put("msg", "添加成功!");
return ret;
}
/**
* 房屋类型信息编辑操作
* @param roomType
* @return
*/
@RequestMapping(value="/edit",method=RequestMethod.POST)
@ResponseBody
public Map<String, String> edit(RoomType roomType){
Map<String, String> ret = new HashMap<String, String>();
if(roomType == null){
ret.put("type", "error");
ret.put("msg", "请填写正确的房屋类型信息!");
return ret;
}
if(StringUtils.isEmpty(roomType.getName())){
ret.put("type", "error");
ret.put("msg", "房屋类型名称不能为空!");
return ret;
}
RoomType existRoomType = roomTypeService.find(roomType.getId());
if(existRoomType == null){
ret.put("type", "error");
ret.put("msg", "未找到该数据!");
return ret;
}
int offset = roomType.getRoomNum() - existRoomType.getRoomNum();
roomType.setAvilableNum(existRoomType.getAvilableNum() + offset);
if(roomType.getAvilableNum() <= 0){
roomType.setAvilableNum(0);//没有可用房屋
roomType.setStatus(0);//房型已满
if(roomType.getAvilableNum() + existRoomType.getLivedNum() + existRoomType.getBookNum() > roomType.getRoomNum()){
ret.put("type", "error");
ret.put("msg", "房屋数设置不合理!");
return ret;
}
}
if(roomTypeService.edit(roomType) <= 0){
ret.put("type", "error");
ret.put("msg", "修改失败,请联系管理员!");
return ret;
}
ret.put("type", "success");
ret.put("msg", "修改成功!");
return ret;
}
3、房屋管理人员对租赁订单管理功能模块
房屋管理人员对用户前台下的订单信息进行增删改查操作,采用Ajax发送异步请求将租赁信息发送到控制层,控制层发送数据到业务逻辑层,业务逻辑层通过调用 DAO层来访问数据库从而执行更改并返回结果。
该模块控制层主要代码:
@RequestMapping(value="/edit",method=RequestMethod.POST)
@ResponseBody
public Map<String, String> edit(BookOrder bookOrder){
Map<String, String> ret = new HashMap<String, String>();
if(bookOrder == null){
ret.put("type", "error");
ret.put("msg", "请填写正确的出租订单信息!");
return ret;
}
if(bookOrder.getAccountId() == null){
ret.put("type", "error");
ret.put("msg", "用户不能为空!");
return ret;
}
if(bookOrder.getRoomTypeId() == null){
ret.put("type", "error");
ret.put("msg", "房屋不能为空!");
return ret;
}
if(StringUtils.isEmpty(bookOrder.getName())){
ret.put("type", "error");
ret.put("msg", "出租订单联系人名称不能为空!");
return ret;
}
if(StringUtils.isEmpty(bookOrder.getMobile())){
ret.put("type", "error");
ret.put("msg", "出租订单联系人手机号不能为空!");
return ret;
}
if(StringUtils.isEmpty(bookOrder.getIdCard())){
ret.put("type", "error");
ret.put("msg", "联系人身份证号不能为空!");
return ret;
}
if(StringUtils.isEmpty(bookOrder.getArriveDate())){
ret.put("type", "error");
ret.put("msg", "租赁时间不能为空!");
return ret;
}
if(StringUtils.isEmpty(bookOrder.getLeaveDate())){
ret.put("type", "error");
ret.put("msg", "结算时间不能为空!");
return ret;
}
BookOrder existBookOrder = bookOrderService.find(bookOrder.getId());
if(existBookOrder == null){
ret.put("type", "error");
ret.put("msg", "请选择正确的数据进行编辑!");
return ret;
}
if(bookOrderService.edit(bookOrder) <= 0){
ret.put("type", "error");
ret.put("msg", "编辑失败,请联系管理员!");
return ret;
}
//判断房屋是否发生变化
if(existBookOrder.getRoomTypeId().longValue() != bookOrder.getRoomTypeId().longValue()){
//房屋发生了变化
//首先恢复原来房屋的出租数及可租赁数
RoomType oldRoomType = roomTypeService.find(existBookOrder.getRoomTypeId());
oldRoomType.setAvilableNum(oldRoomType.getAvilableNum() + 1);
oldRoomType.setBookNum(oldRoomType.getBookNum() - 1);
roomTypeService.updateNum(oldRoomType);
if(oldRoomType.getStatus() == 0){
//旧的房屋原来是以租赁,恢复状态
if(oldRoomType.getAvilableNum() > 0){
//设置成状态可用
oldRoomType.setStatus(1);
roomTypeService.edit(oldRoomType);
}
}
//修改新的房屋的可租赁数和出租数
RoomType newRoomType = roomTypeService.find(bookOrder.getRoomTypeId());
newRoomType.setAvilableNum(newRoomType.getAvilableNum() - 1);
newRoomType.setBookNum(newRoomType.getBookNum() + 1);
roomTypeService.updateNum(newRoomType);
if(newRoomType.getAvilableNum() <= 0){
//没有可以出租的房屋
newRoomType.setStatus(0);//设置成已出租
roomTypeService.edit(newRoomType);
}
}
ret.put("type", "success");
ret.put("msg", "修改成功!");
return ret;
}
五、其他截图
六、论文
资源下载,包括项目和论文