Bootstrap

基于JAVA+SpringBoot+Vue+协同过滤算法+爬虫的前后端分离的租房系统

✌全网粉丝20W+,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌

🍅文末获取项目下载方式🍅


一、项目背景介绍:

随着城市化进程的加快,租房需求逐渐增多,传统的租房方式已经无法满足人们的需求。为了提高效率,降低成本,越来越多的人选择通过互联网寻找租房信息。因此,开发一款基于JAVA+SpringBoot+Vue+协同过滤算法+爬虫的前后端分离的租房系统具有很大的市场需求和发展潜力。

该租房系统采用前后端分离的设计模式,前端使用Vue框架进行开发,后端使用Java语言和SpringBoot框架搭建。通过爬虫技术抓取大量的租房数据,利用协同过滤算法对用户进行个性化推荐,提高用户的找房体验。同时,系统还具备发布房源、在线签约、支付房租等功能,为用户提供一站式的租房服务。

在实现过程中,前后端通过RESTful API进行数据交互,前端负责展示界面和与用户的交互,后端负责处理业务逻辑和数据存储。通过这种方式,可以使前端和后端各司其职,提高开发效率,降低维护成本。

总之,基于JAVA+SpringBoot+Vue+协同过滤算法+爬虫的前后端分离的租房系统是一款集功能丰富、易用性高、性能优越于一体的租房平台,有望为广大租房者提供更加便捷、高效的服务。

二、项目技术简介:

  1. JAVA:Java是一门面向对象编程语言,不仅吸收了C++语言的各种优点,还摒弃了C++里难以理解的多继承、指针等概念,因此Java语言具有功能强大和简单易用两个特征。Java语言作为静态面向对象编程语言的代表,极好地实现了面向对象理论,允许程序员以优雅的思维方式进行复杂的编程。
  2. Vue:Vue (发音为 /vjuː/,类似 view) 是一款用于构建用户界面的JavaScript框架。它基于标准HTML、CSS和JavaScript构建,并提供了一套声明式的、组件化的编程模型,帮助开发者高效地开发用户界面。
    Vue是一个独立的社区驱动的项目,它是由尤雨溪在2014年作为其个人项目创建, 是一个成熟的、经历了无数实战考验的框架,它是目前生产环境中使用最广泛的JavaScript框架之一,可以轻松处理大多数web应用的场景,并且几乎不需要手动优化,并且Vue完全有能力处理大规模的应用。
  3. Element-UI:Element,一套为开发者、设计师和产品经理准备的基于 Vue 2.0 的桌面端组件库。
  4. SpringBoot:Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者。
  5. Mybatis-Plus:MyBatis-Plus(简称 MP)是一个 MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为 简化开发、提高效率而生。
  6. 协同过滤算法:协同过滤算法是一种基于用户历史行为数据的推荐算法,它通过对用户历史行为数据的挖掘发现用户的偏好,基于不同的偏好对用户进行群组划分并推荐品味相似的商品。协同过滤推荐算法分为两类,分别是基于用户的协同过滤算法和基于物品的协同过滤算法。基于用户的协同过滤算法是根据用户之间的相似性来进行推荐,而基于物品的协同过滤算法则是根据物品之间的相似性来进行推荐。
  7. 爬虫:网络爬虫是一种按照一定的规则,自动地抓取万维网信息的程序或者脚本。 通俗地讲,我们把互联网比作一张大蜘蛛网,每个站点资源比作蜘蛛网上的一个结点,爬虫就像一只蜘蛛,按照设计好的路线和规则在这张蜘蛛网上找到目标结点,获取资源。

三、系统功能模块介绍:

功能模块图

四、数据库设计:

1:‘区域表’(area)

字段名类型默认值列注释
idbigintNULL区域编号
area_namevarcharNULL区域名称
create_timedatetimeNULL创建时间
data_urlvarcharNULL数据获取链接
statusintNULL数据状态[0:未获取,1:已获取]
city_idbigintNULL所属城市编号

2:‘轮播图表’(banner)

字段名类型默认值列注释
idbigintNULL轮播图编号
banner_urlvarcharNULL轮播图地址
create_timedatetimeNULL创建时间
statusintNULL状态[0:启用,1:禁用]

3:‘城市表’(citys)

字段名类型默认值列注释
idbigintNULL城市编号
city_namevarcharNULL城市名称
create_timedatetimeNULL创建时间

4:‘房屋收藏表’(collect)

字段名类型默认值列注释
idbigintNULL收藏编号
house_idbigintNULL房屋编号
user_idbigintNULL用户编号
homeowner_idbigintNULL房主编号
create_timedatetimeNULL创建时间

5:‘房主信息表’(homeowner)

字段名类型默认值列注释
idbigintNULL房主编号
usernamevarcharNULL用户名
passwordvarcharNULL密码
homeowner_namevarcharNULL房主姓名
telvarcharNULL联系方式
ageintNULL年龄
sexintNULL性别[0:男,1:女]
id_cardvarcharNULL身份证号
create_timedatetimeNULL创建时间
header_imgvarcharNULL照片

6:‘房源信息’(house)

字段名类型默认值列注释
idbigintNULL房屋序号
homeowner_idbigintNULL房主编号
home_namevarcharNULL房屋名称
detail_urltextNULL详情URL
pricevarcharNULL价格
img_urltextNULL大图
locationvarcharNULL所处位置
areavarcharNULL面积
abaftvarcharNULL朝向
house_typevarcharNULL户型
tagsvarcharNULL标签
create_timedatetimeNULL创建时间
number_strvarcharNULL验真编号
detailtextNULL详细信息
is_allintNULL是否整租[0:是,1:否]
subscribeintNULL预约看房[0:是,1:否]
area_idbigintNULL区域编号
statusintNULL审核状态[2:待审核,0:通过,1:拒绝]
causevarcharNULL拒绝原因
phonevarcharNULL联系方式
update_timedatetimeNULL审核日期
sale_statusintNULL租售状态[0:未出租,1:已出租,2:下架]

7:‘房屋图片表’(house_img)

字段名类型默认值列注释
idbigintNULL图片编号
img_urltextNULL图片地址
house_idbigintNULL房屋编号

8:‘管理员表’(manage)

字段名类型默认值列注释
idbigintNULL管理员编号
user_namevarcharNULL用户名
pass_wordvarcharNULL密码
photo_imgvarcharNULL图片
namevarcharNULL名称

9:‘留言表’(messages)

字段名类型默认值列注释
idbigintNULL留言编号
homeowner_idbigintNULL房主编号
house_idbigintNULL房源编号
user_idbigintNULL用户编号
create_timedatetimeNULL创建时间
answervarcharNULL回复
contentvarcharNULL留言内容

10:‘公告信息表’(notice)

字段名类型默认值列注释
idbigintNULL公告编号
banner_imgvarcharNULL公告图片
contenttextNULL公告内容
infovarcharNULL公告简介
create_timedatetimeNULL创建时间
titlevarcharNULL公告标题

11:orders(orders)

字段名类型默认值列注释
idbigintNULL订单编号
user_idbigintNULL用户编号
house_idbigintNULL房源编号
homeowner_idbigintNULL房主编号
create_timedatetimeNULL创建时间
start_timedatetimeNULL租赁开始时间
end_timedatetimeNULL租赁结束时间
contract_urlvarcharNULL合同文件地址
contract_imgvarcharNULL合同图片
contract_titlevarcharNULL合同标题
moneyvarcharNULL租金
is_payintNULL是否支付[0:已支付,2:未支付]
statusintNULL订单状态[0:审核中,1:审核通过,2:审核不通过]
causevarcharNULL不通过原因
remarktextNULL备注
evaluatetextNULL评价内容
evaluate_timedatetimeNULL评价时间
house_starintNULL房屋星级
service_starintNULL服务星级

12:‘预约表’(subscribes)

字段名类型默认值列注释
idbigintNULL预约编号
house_idbigintNULL房屋编号
create_timedatetimeNULL创建时间
subscribe_timedatetimeNULL预约时间
user_idbigintNULL用户编号
homeowner_idbigintNULL房主编号
remarktextNULL备注
statusintNULL状态[0:房主审核中,1:房主审核通过,2:房主拒绝,3:已完成]
causetextNULL拒绝原因

13:‘用户信息表’(users)

字段名类型默认值列注释
idbigintNULL用户编号
usernamevarcharNULL用户名
passwordvarcharNULL密码
nick_namevarcharNULL用户姓名
telvarcharNULL联系方式
ageintNULL年龄
sexintNULL性别[0:男,1:女]
id_cardvarcharNULL身份证号
create_timedatetimeNULL创建时间
header_imgvarcharNULL照片

五、功能模块:

  1. 租客登录注册:租客进行登录注册

    租客登录注册

  2. 房源智能推荐:房源智能推荐(基于协同过滤算法)

    房源智能推荐

  3. 房源筛选:城市,区域,关键字,标签,租房方式等组合筛选

    房源筛选

  4. 房源详情:查看房源的详细信息

    房源详情

  5. 网站公告:系统管理员发布的租房公告

    网站公告

  6. 个人中心:个人信息,密码修改,历史留言,记录预约记(预约看房记录),下单记录(下单租房,合同签订),订单评价(对租赁中的房屋房东进行评价)

    个人中心

  7. 房源录入:房主对房源进行录入

    房源录入

  8. 管理员后台:管理员登录
    用户端首页轮播图管理
    网站管理网站公告管理
    管理员管理(新增管理员协助网站管理)
    房主信息管理租客信息管理
    系统用户管理
    城市区域内置爬虫可通过链接初始化区域房源数据房源详情对房主提交的房源进行审核(审核不通过即可下架)对房主上传的房源图片进行审核 (不通过可删除)房源图片
    地区管理
    房源管理
    租客预约看房记录管理房主用户之间的沟通留言(不合理即可删除)
    预约管理留言管理订单管理
    租客和房主的房屋租赁信息管理(保证租房的安全)

    管理员后台

六、代码示例:

@PostMapping(value = "/recommend")
    public ReturnMsg findUserRecommend(@RequestBody HouseDTO houseDTO, HttpServletRequest request) {
        String ipAddr = IpUtil.getIpAddr(request);
        String key = houseDTO.getUserId() != null ? houseDTO.getUserId().toString() : ipAddr;
        return ReturnMsg.ok(baseService.findUserRecommend(houseDTO, key));
    }

    @GetMapping(value = "/select/options/{cityId}")
    public ReturnMsg getSelectOptions(@PathVariable Long cityId) {
        AreaDTO areaDTO = new AreaDTO();
        areaDTO.setCityId(cityId);
        List<AreaDTO> areaDTOS = areaService.findList(areaDTO);
        Map<String, Object> optionsMap = new HashMap<>();
        optionsMap.put("areaList", areaDTOS);
        optionsMap.put("tagList", LocalCache.getTagSetCache());
        return ReturnMsg.ok(optionsMap);
    }

    @PostMapping(value = "/user/page")
    public ReturnMsg getUserPage(@RequestBody HouseDTO houseDTO, HttpServletRequest request) {
        IPage<HouseDTO> page = new Page<>();
        page.setCurrent(houseDTO.getCurrent());
        page.setSize(houseDTO.getPageSize());
        LambdaQueryWrapper<HouseDTO> queryWrapper = new LambdaQueryWrapper<>();
        queryWrapper.eq(HouseDTO::getStatus, 0)
                .in(HouseDTO::getSaleStatus, 0, 1);
        if (StrUtil.isNotEmpty(houseDTO.getHomeName())) {
            queryWrapper.like(HouseDTO::getHomeName, houseDTO.getHomeName());
        }
        if (houseDTO.getAreaId() != null) {
            queryWrapper.eq(HouseDTO::getAreaId, houseDTO.getAreaId());
        }
        if (houseDTO.getIsAll() != null) {
            queryWrapper.eq(HouseDTO::getIsAll, houseDTO.getIsAll());
        }
        if (houseDTO.getCityId() != null && houseDTO.getAreaId() == null) {
            AreaDTO areaDTO = new AreaDTO();
            areaDTO.setCityId(houseDTO.getCityId());
            List<AreaDTO> areaDTOS = areaService.findList(areaDTO);
            queryWrapper.in(HouseDTO::getAreaId, areaDTOS.stream().map(AreaDTO::getId).collect(Collectors.toList()));
        }
        List<String> tagStrList = houseDTO.getTagStrList();
        String ipAddr = IpUtil.getIpAddr(request);
        if (CollectionUtil.isNotEmpty(tagStrList)) {
            int i = 0;
            for (String tag : tagStrList) {
                if (i == 0) {
                    queryWrapper.like(HouseDTO::getTags, tag);
                } else {
                    queryWrapper.or().like(HouseDTO::getTags, tag);
                }
                i++;
            }
            String key = houseDTO.getUserId() != null ? houseDTO.getUserId().toString() : ipAddr;
            LocalCache.setUserTagSetCache(key, tagStrList);
        }
        return ReturnMsg.ok(baseService.page(page, queryWrapper));
    }

八、源码获取:

大家点赞、收藏、关注、评论啦 、查看👇🏻👇🏻👇🏻获取项目下载链接,博主联系方式👇🏻👇🏻👇🏻

链接点击直达:下载链接

;