🍅 作者主页:Selina .a
🍅 简介:Java领域优质创作者🏆、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行交流合作。
主要内容:SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app、大数据、物联网、机器学习等设计与开发。
🍅文末获取源码联系🍅
目录
课题的提出
随着社会的不断进步与发展,人们经济水平也不断的提高,于是对各行各业需求也越来越高。特别是从2019年新型冠状病毒爆发以来,利用计算机网络来处理各行业事务这一概念更深入人心,由于工作繁忙以及疫情的原因,用户到房源公司进行房屋求租也是比较难实施的。如果开发一款房屋租赁系统,可以让用户在最短的时间里享受到最快捷的服务,提高管理员的整体工作水平,简化工作程序,这对用户、房东和管理员来说都是一件非常乐意的事情。
本论文针对房源信息、预约和求租的特点,采用JAVA等编写语言,springboot框架,以MySQL为数据库,B/S为系统构架,对房屋租赁系统进行设计和开发。通过使用本系统可有效地减少运营成本,提高管理效率。
数据库设计
在每一个系统中数据库有着非常重要的作用,数据库的设计得好将会增加系统的效率以及系统各逻辑功能的实现。所以数据库的设计我们要从系统的实际需要出发,才能使其更为完美的符合系统功能的实现。
概念模型是对现实中的问题出现的事物的进行描述,ER图是由实体及其关系构成的图,通过E-R图可以清楚地描述系统涉及到的实体之间的相互关系。
用户信息实体体属图如下所示。
房东信息实体属图如下所示。
投诉信息实体属图如下所示。
求租信息实体属图如下所示。
系统功能设计
当游客打开系统的网址后,首先看到的就是首页界面。在这里,游客能够看到房屋租赁系统的导航条显示首页、房源信息、公告信息、留言反馈、后台管理等。系统首页界面如图5-1所示:
点击用户注册,用户通过注册页面填写账号、密码、确认密码、姓名、性别、邮箱、手机号码、上传头像等信息,并点击注册操作,如图5-2所示。
点击用户登录,用户通过登录页面输入用户名、密码,并点击登录操作,如图5-3所示。
用户点击房源信息;在房源信息页面的搜索栏输入房屋名称、房屋类型、房屋图片、房屋地址、状态、朝向、面积、租金、区、县、房东账号、房东姓名、联系手机、发布日期等信息,如有需要可以点我收藏,并且进行预约、咨询和投诉等操作;如图5-4所示。
房东注册、登录,房东通过注册、登录页面输入信息完成后,并点击注册或者登录操作,如图5-5所示。
房东登录系统后,可以对首页、个人中心、房源信息管理、预约信息管理、合同信息管理、在线咨询管理、咨询回复管理、申诉信息管理、求租信息管理、求租回复管理等功能进行相应操作,如图5-6所示。
用户登录,用户通过登录页面输入信息完成后,并点击登录操作,如图5-7所示。
用户登录系统后,可以对首页、个人中心、预订记录管理、入住记录管理、评价记录管理、取消预定记录管理等功能进行相应操作,如图5-8所示。
管理员如果要登录到系统后台,首先得先通过输入账号、密码、选择角色进行登录的操作。管理员登录界面如图5-9所示。
管理员登录到系统后台后,可以对首页、个人中心、用户管理、房东管理、区管理、县管理、房源信息管理、房屋类型管理、预约信息管理、合同信息管理、在线咨询管理、咨询回复管理、投诉信息管理、申诉信息管理、求租类型管理、求租信息管理、求租回复管理、留言反馈、系统管理等功能模块进行管理;如图5-10所示。
管理员点击房东管理,在房东管理页面,对房东账号、房东姓名、性别、身份证、联系手机、房产证、审核回复、审核状态、审核等内容,进行查询或者修改、删除房东信息等操作,如图5-11所示。
管理员点击用户管理,在用户管理页面,对账号、姓名、性别、邮箱、手机号码、头像等内容,进行查询或者修改、删除用户信息等操作,如图5-12所示。
管理员点击房源信息管理,在房源信息管理页面,对房屋名称、房屋类型、房屋图片、房屋地址、状态、朝向、面积、租金、区、县、房东账号、房东姓名、联系手机、发布日期、审核回复、审核状态等内容,进行查询或者修改、删除房源信息等操作,如图5-13所示。
管理员点击预约信息管理,在预约信息管理页面,对房屋名称、房屋类型、房屋地址、租金、房东账号、房东姓名、联系手机、账号、姓名、手机号码、预约时间、预约备注、申请日期、审核回复、审核状态等内容,进行查询或者删除预约信息等操作,如图5-14所示。
管理员点击合同信息管理,在合同信息管理页面,对房屋名称、房屋类型、房屋地址、租金、房东账号、房东姓名、联系手机、合同附件、账号、姓名、手机号码、签订日期、是否支付等内容,进行查询或者删除合同信息等操作,如图5-15所示。
管理员点击在线咨询管理,在在线咨询管理页面,对房屋名称、房名称东编号账号、房东姓名、账号、姓名、咨询日期等内容,进行查询或者删除在线咨询等操作,如图5-16所示。
管理员点击投诉信息管理,在投诉信息管理页面,对投诉编号、房屋名称、房东账号、房东姓名、投诉时间、账号、姓名、审核回复、审核状态、审核等内容,进行查询或者删除投诉信息等操作,如图5-17所示。
关键代码
package com.controller;
import java.util.Arrays;
import java.util.Calendar;
import java.util.Date;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
import com.annotation.IgnoreAuth;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.entity.TokenEntity;
import com.entity.UserEntity;
import com.service.TokenService;
import com.service.UserService;
import com.utils.CommonUtil;
import com.utils.MPUtil;
import com.utils.PageUtils;
import com.utils.R;
import com.utils.ValidatorUtils;
/**
* 登录相关
*/
@RequestMapping("users")
@RestController
public class UserController{
@Autowired
private UserService userService;
@Autowired
private TokenService tokenService;
/**
* 登录
*/
@IgnoreAuth
@PostMapping(value = "/login")
public R login(String username, String password, String captcha, HttpServletRequest request) {
UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
if(user==null || !user.getPassword().equals(password)) {
return R.error("账号或密码不正确");
}
String token = tokenService.generateToken(user.getId(),username, "users", user.getRole());
return R.ok().put("token", token);
}
/**
* 注册
*/
@IgnoreAuth
@PostMapping(value = "/register")
public R register(@RequestBody UserEntity user){
// ValidatorUtils.validateEntity(user);
if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {
return R.error("用户已存在");
}
userService.insert(user);
return R.ok();
}
/**
* 退出
*/
@GetMapping(value = "logout")
public R logout(HttpServletRequest request) {
request.getSession().invalidate();
return R.ok("退出成功");
}
/**
* 密码重置
*/
@IgnoreAuth
@RequestMapping(value = "/resetPass")
public R resetPass(String username, HttpServletRequest request){
UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
if(user==null) {
return R.error("账号不存在");
}
user.setPassword("123456");
userService.update(user,null);
return R.ok("密码已重置为:123456");
}
/**
* 列表
*/
@RequestMapping("/page")
public R page(@RequestParam Map<String, Object> params,UserEntity user){
EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();
PageUtils page = userService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.allLike(ew, user), params), params));
return R.ok().put("data", page);
}
/**
* 列表
*/
@RequestMapping("/list")
public R list( UserEntity user){
EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();
ew.allEq(MPUtil.allEQMapPre( user, "user"));
return R.ok().put("data", userService.selectListView(ew));
}
/**
* 信息
*/
@RequestMapping("/info/{id}")
public R info(@PathVariable("id") String id){
UserEntity user = userService.selectById(id);
return R.ok().put("data", user);
}
/**
* 获取用户的session用户信息
*/
@RequestMapping("/session")
public R getCurrUser(HttpServletRequest request){
Long id = (Long)request.getSession().getAttribute("userId");
UserEntity user = userService.selectById(id);
return R.ok().put("data", user);
}
/**
* 保存
*/
@PostMapping("/save")
public R save(@RequestBody UserEntity user){
// ValidatorUtils.validateEntity(user);
if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {
return R.error("用户已存在");
}
userService.insert(user);
return R.ok();
}
/**
* 修改
*/
@RequestMapping("/update")
public R update(@RequestBody UserEntity user){
// ValidatorUtils.validateEntity(user);
UserEntity u = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername()));
if(u!=null && u.getId()!=user.getId() && u.getUsername().equals(user.getUsername())) {
return R.error("用户名已存在。");
}
userService.updateById(user);//全部更新
return R.ok();
}
/**
* 删除
*/
@RequestMapping("/delete")
public R delete(@RequestBody Long[] ids){
userService.deleteBatchIds(Arrays.asList(ids));
return R.ok();
}
}
专栏推荐
Spring Boot+Vue+CSS+JavaScript+HTML等技术项目专栏推荐
推荐项目
基于Node.js+Vue+MySQL的小型企业工资管理系统
基于Spring Boot+Android+MySQL的记录生活管理系统
源码获取
大家点赞、收藏、关注、评论啦 、查看👇🏻获取联系方式👇🏻