4 房屋租赁管理系统详细设计与实现
房屋租赁管理系统的详细设计与实现主要是根据前面的房屋租赁管理系统的需求分析和房屋租赁管理系统的总体设计来设计页面并实现业务逻辑。主要从房屋租赁管理系统界面实现、业务逻辑实现这两部分进行介绍。
4.1用户功能模块
4.1.1 前台首页界面
当进入房屋租赁管理系统的时候,系统以上中下的布局进行展示,首先映入眼帘的是系统的导航栏,下面是轮播图,再往下是新闻资讯,其主界面展示如下图4-1所示。
图4-1 前台首页界面图
4.1.2 用户注册界面
房屋租赁管理系统的游客和租客用户时可以进行注册登录,当用户右上角“注册”按钮的时候,当填写上自己的账号+密码+确认密码+昵称+邮箱+手机号等后再点击“注册”按钮后将会先验证输入的有没有空数据,再次验证密码和确认密码是否是一样的,最后验证输入的账户名和数据库表中已经注册的账户名是否重复,只有都验证没问题后即可用户注册成功。其用用户注册界面展示如下图4-2所示。
图4-2注册界面图
注册关键代码如下:
/**
* 注册
* @param user
* @return
*/
@PostMapping("register")
public Map<String, Object> signUp(@RequestBody User user) {
// 查询用户
Map<String, String> query = new HashMap<>();
Map<String,Object> map = JSON.parseObject(JSON.toJSONString(user));
query.put("username",user.getUsername());
List list = service.selectBaseList(service.select(query, new HashMap<>()));
if (list.size()>0){
return error(30000, "用户已存在");
}
map.put("password",service.encryption(String.valueOf(map.get("password"))));
service.insert(map);
return success(1);
}
4.1.3 用户登录界面
房屋租赁管理系统中的前台上注册后的用户是可以通过自己的账户名和密码进行登录的,当租客用户输入完整的自己的账户名和密码信息并点击“登录”按钮后,将会首先验证输入的有没有空数据,再次验证输入的账户名+密码和数据库中当前保存的用户信息是否一致,只有在一致后将会登录成功并自动跳转到房屋租赁管理系统的首页中;否则将会提示相应错误信息,用户登录界面如下图4-3所示。
图4-3用户登录界面图
登录的逻辑代码如下所示。
/**
* 登录
* @param data
* @param httpServletRequest
* @return
*/
@PostMapping("login")
public Map<String, Object> login(@RequestBody Map<String, String> data, HttpServletRequest httpServletRequest) {
log.info("[执行登录接口]");
String username = data.get("username");
String email = data.get("email");
String phone = data.get("phone");
String password = data.get("password");
List resultList = null;
Map<String, String> map = new HashMap<>();
if(username != null && "".equals(username) == false){
map.put("username", username);
resultList = service.select(map, new HashMap<>()).getResultList();
}
else if(email != null && "".equals(email) == false){
map.put("email", email);
resultList = service.select(map, new HashMap<>()).getResultList();
4.1.4 房屋资讯界面
当访客点击房屋租赁管理系统中导航栏上的“房屋资讯”后将会进入到该“房屋资讯”列表的界面,然后选择想要看的新闻资讯,点击进入到详细界面,在详细界面可以收藏+赞+评论等操作,房屋资讯界面如下图4-4所示。
图4-4房屋资讯界面图
4.1.6 房屋信息界面
当用户点击“房屋信息”这一菜单按钮,会显示管理员在后台发布的所有的房屋信息,支持通过关键词对房屋信息进行搜索,选择需要的房屋信息点击可以进入到房屋信息详细的介绍界面,在详细界面可以查看到房屋信息的房东用户、房屋名称、房屋房型、房屋面积、房屋朝向等信息,同时可以进行租赁、点赞、收藏、评论等操作,房屋信息界面如下图4-5所示。
图4-5 房屋信息界面图
4.1.7预订租房界面
当用户在房屋信息详情界面想要进行预约看房,点击下方的“预定租房”按钮,就会跳转到预定租房信息填写界面,根据界面提示输入预定租房信息,点击“提交”按钮,预定租房就完成了。预租房界面如下图4-6所示。
图4-6预订租房界面图
4.1.8房东用户个人中心界面
当用户点击右上角“我的”这个按钮,会出现子菜单,点击“个人中心”可以对个人首页、房屋信息、租房订单、退租信息、租房合同、收支信息、收藏、登录系统的密码进行设置管理,个人中心界面如下图4-7所示。
图4-7房东用户个人中心界面图
4.2管理员功能模块
4.2.2用户管理界面
管理员点击“用户管理”这一菜单会显示管理员、房东用户和租客用户这三个子菜单,管理员可以对这三个角色的信息进行增删改查操作。界面如下图4-9所示。
图4-8用户管理界面图
5系统测试
5.1 系统测试用例
系统测试包括:用户登录功能测试、房屋信息展示功能测试、房屋信息添加、房屋信息搜索、密码修改、预约看房功能测试,如表5-1、5-2、5-3、5-4、5-5、5-6所示:
用户登录功能测试:
表5-1 用户登录功能测试表
用例名称 |
用户登录系统 |
目的 |
测试用户通过正确的用户名和密码可否登录功能 |
前提 |
未登录的情况下 |
测试流程 |
1) 进入登录页面 2) 输入正确的用户名和密码 |
预期结果 |
用户名和密码正确的时候,跳转到登录成功界面,反之则显示错误信息,提示重新输入 |
实际结果 |
实际结果与预期结果一致 |
房屋信息查看功能测试:
表5-2 房屋信息查看功能测试表
用例名称 |
房屋信息查看 |
目的 |
测试房屋信息查看功能 |
前提 |
用户登录 |
测试流程 |
点击房屋信息列表 |
预期结果 |
可以查看到所有房屋信息 |
实际结果 |
实际结果与预期结果一致 |
房东用户添加房屋信息界面测试:
表5-3 房东用户添加房屋信息界面测试表
用例名称 |
添加房屋信息测试用例 |
目的 |
测试房屋信息添加功能 |
前提 |
房东用户正常登录情况下 |
测试流程 |
1)房东用户点击房屋信息,然后点击添加后并填写信息。 2)点击进行提交。 |
预期结果 |
提交以后,页面首页会显示新的房屋信息 |
实际结果 |
实际结果与预期结果一致 |
房屋信息搜索功能测试:
表5-4房屋信息搜索功能测试表
用例名称 |
房屋信息搜索测试 |
目的 |
测试房屋信息搜索功能 |
前提 |
无 |
测试流程 |
1)在搜索框填入搜索关键字。 2)点击搜索按钮。 |
预期结果 |
页面显示包含有搜索关键字的房屋信息 |
实际结果 |
实际结果与预期结果一致 |
密码修改搜索功能测试:
表5-5 密码修改功能测试表
用例名称 |
密码修改测试用例 |
目的 |
测试管理员密码修改功能 |
前提 |
管理员用户正常登录情况下 |
测试流程 |
1)管理员密码修改并完成填写。 2)点击进行提交。 |
预期结果 |
使用新的密码可以登录 |
实际结果 |
实际结果与预期结果一致 |
预订租房功能测试:
表5-6预订租房功能测试表
用例名称 |
预订租房测试用例 |
目的 |
测试用户预订租房功能 |
前提 |
用户正常登录情况下 |
测试流程 |
1)搜索查看房屋信息,点击预订租房。 2)填写预订租房信息,点击进行提交。 |
预期结果 |
预订租房成功 |
实际结果 |
实际结果与预期结果一致 |
5.2 系统测试结果
通过编写房屋租赁管理系统的测试用例,已经检测完毕用户登录模块、房屋信息展示模块、房屋信息添加模块、房屋信息搜索模块、密码修改模块、预订租房模块功能测试,通过这6大模块为房屋租赁管理系统的后期推广运营提供了强力的技术支撑。