摘 要
本文旨在设计与实现一个基于Spring Boot的智能购房推荐系统,系统主要包括管理员、普通用户、房源信息、房屋类型、地区名称和需求信息等关键模块。通过该系统,用户可以根据个人需求和偏好,快速找到符合条件的购房信息。管理员可以进行房源信息管理和用户管理等操作。系统将利用智能推荐算法,结合用户的历史行为和偏好,为用户提供个性化的购房推荐结果。同时,系统还提供房屋类型和地区名称的分类和检索功能,方便用户快速筛选和查找感兴趣的房源。通过该智能购房推荐系统,用户能够高效准确地获取购房信息,提升购房决策的满意度和效率。
关键词:智能购房推荐系统;Java语言;Springboot技术
Design and Implementation of an Intelligent Home Purchase Recommendation System
Abstract
This article aims to design and implement an intelligent home purchase recommendation system based on Spring Boot, which mainly includes key modules such as administrator, regular users, housing information, housing type, regional name, and demand information. Through this system, users can quickly find eligible purchasing information based on their personal needs and preferences. Administrators can perform operations such as property information management and user management. The system will utilize intelligent recommendation algorithms, combined with the user's historical behavior and preferences, to provide personalized home purchase recommendation results for the user. At the same time, the system also provides classification and retrieval functions for house types and area names, making it convenient for users to quickly filter and search for houses of interest. Through this intelligent home purchase recommendation system, users can efficiently and accurately obtain purchasing information, improving the satisfaction and efficiency of purchasing decisions.
Key words:Intelligent home purchase recommendation system; Java language; Springboot technology
目 录
随着城市化进程的加快和人们对舒适居住环境的需求增加,购房成为了人们重要的生活目标。然而,购房过程中存在信息不对称、选择困难等问题,使得用户在众多房源中难以快速准确地找到符合自身需求的房屋。因此,设计与实现一个智能购房推荐系统具有重要的研究背景和意义。该系统通过利用智能推荐算法,结合用户的历史行为、喜好和需求,能够个性化地向用户推荐适合其要求的房屋。用户可以根据自己的预算、地理位置、房屋类型等条件进行筛选,并获取精准的购房推荐结果。这将大大减少用户的信息搜索时间和购房决策的风险,提高购房效率和满意度。
此外,智能购房推荐系统还能够提供房屋类型和地区名称的分类和检索功能,方便用户快速查找感兴趣的房源。同时,系统管理员可以进行房源信息管理和用户管理等操作,保证系统的正常运行和数据的更新。通过该系统的研究与实现,能够有效解决用户在购房过程中的信息不对称和选择困难问题,提供个性化的购房推荐服务,为用户提供更加便捷、准确的购房体验。对于购房者来说,这将节省时间和精力,提高购房决策的质量;对于房产中介机构来说,这将提升客户满意度和竞争力,增加业务转化率。因此,智能购房推荐系统在改善购房体验、促进房地产市场的发展以及提升城市居民生活质量方面具有重要的研究背景和实际意义。
在研究方面,学术界和行业内涌现出许多智能推荐算法和模型,如基于协同过滤、内容过滤等技术的推荐方法。这些方法通过分析用户的历史行为数据和房屋特征,实现了一定程度上的个性化推荐。然而,如何在海量的房源信息中提高推荐的准确性和效果,仍然是一个具有挑战性的问题。
在开发方面,一些房地产中介机构和在线房产平台已经开始尝试利用智能购房推荐系统来提供更好的服务。他们建立了大规模的房屋数据库,并利用数据挖掘和机器学习技术,为用户提供个性化的购房建议。然而,房屋信息的真实性和完整性、用户隐私保护等问题仍然需要关注和解决。
此外,用户体验也是智能购房推荐系统开发中的重要考虑因素。用户希望系统能够提供直观、友好的界面,便捷的筛选和排序功能,以及即时的反馈和推荐结果。因此,系统开发者需要注重用户界面设计和交互体验,提高用户满意度和使用效果。
综上所述,智能购房推荐系统的研究与开发已经取得了一定的进展,但仍面临着推荐准确性、数据可靠性和用户体验等方面的挑战。进一步的研究应该关注算法优化、数据质量控制和用户需求分析等问题,以提高系统的性能和实用性,并为购房者提供更好的购房决策支持。
智能购房推荐系统的主要研究内容包括管理员、普通用户、房源信息、房屋类型、地区名称和需求信息等关键模块。其中,管理员功能涵盖了账号管理和房源信息管理,普通用户可以进行注册、登录和个人信息管理,房源信息包括房屋类型、地区名称、价格、面积等属性。此外,系统还需要考虑如何对房源信息进行分类和检索,以及如何分析用户提交的需求信息并进行智能推荐。
在研究过程中,需要设计合适的数据结构和数据库模型,确保房源信息的完整性和准确性。同时,还需要探索并应用智能推荐算法,如协同过滤、内容过滤等技术,为用户提供个性化的购房推荐结果。这些算法将基于用户的历史行为和相似用户的喜好,结合房屋类型、地区名称和用户需求等因素,实现精准的推荐。
通过研究智能购房推荐系统的相关内容,我们可以建立一个高效便捷的平台,帮助用户快速找到符合自身需求的房屋。同时,管理员能够更好地管理房源信息,并审核用户提交的需求信息。这将大大提高购房决策的准确性和效率,为用户提供满意的购房体验,并促进房地产市场的发展。因此,研究智能购房推荐系统的相关内容具有重要的理论和实际意义。
本文共有七章,如下所示。
第一章概述了智能购房推荐系统的研究背景与意义;精炼地总结了研究开发现状分析以及研究内容进行研究,最后给出了论文的组成结构。
第二章简要概述了本文所用的开发技术和工具。
第三章简要对系统各业务流程进行需求分析、可行性分析。
第四章对智能购房推荐系统进行设计。
第五章对智能购房推荐系统进行实现,并贴出相关页面截图,语言描述出具体功能实现的操作方法。
第六章对智能购房推荐系统采用测试用例的方式来对一些主要功能模块测试,最后得出测试结果。
第七章总结。
Java编程语言是一种通用的高级编程语言,具有跨平台性和面向对象的特性。它由Sun Microsystems(现在是Oracle Corporation)开发,并于1995年发布。Java编程语言以其简洁、可靠和安全的特点广泛应用于软件开发领域。
Java的跨平台性是其最显著的特点之一。通过Java虚拟机(JVM),可以将Java程序编译为字节码,然后在不同的操作系统上运行。这使得开发人员只需编写一次代码,就能在多个平台上运行,大大提高了开发效率和代码重用性。
另一个重要的特性是Java的面向对象编程(OOP)能力。Java支持封装、继承和多态等面向对象的概念,使开发人员能够更加灵活地组织和管理代码。这种结构化的编程方式使得代码更易于理解、修改和维护。
此外,Java还具有丰富的类库和API(应用程序接口),涵盖了各种功能和领域,如图形用户界面、网络编程、数据库连接等。这些类库和API为开发人员提供了丰富的工具和功能,加速了开发过程。
jQuery是一个快速、简洁且功能强大的JavaScript库。它被设计用于简化HTML文档遍历、事件处理、动画效果和AJAX等常见的客户端脚本操作。通过使用jQuery,开发人员可以更轻松地操作HTML元素、处理用户交互以及与服务器进行异步通信。
jQuery的主要特点包括:
(1)简洁优雅:jQuery提供了简洁的API,使得常见的DOM操作和事件处理变得更加简单和优雅。开发人员可以使用更少的代码来实现复杂的功能,提高开发效率。
(2)跨浏览器兼容性:jQuery封装了许多常见的跨浏览器兼容性问题,使得开发人员无需关注不同浏览器之间的差异。它为开发者提供了统一的接口,确保代码在各种浏览器中正常运行。
(3)强大的选择器:jQuery提供了强大的选择器,使开发人员能够轻松地选取HTML元素,并对其进行操作。这些选择器可以根据元素的标签名、类名、ID、属性等进行精确的定位。
(4)丰富的插件生态系统:jQuery拥有庞大而活跃的插件生态系统,开发人员可以利用这些插件扩展jQuery的功能。这些插件包括图表库、表单验证、日期选择器等,可以帮助开发人员快速实现各种复杂的功能需求。
(5)AJAX支持:jQuery提供了简洁易用的AJAX功能,使得与服务器进行异步通信变得更加方便。开发人员可以轻松地发送AJAX请求、处理响应数据,并在页面上动态更新内容。
MySQL是一种可靠、稳定、灵活且高性能的关系型数据库管理系统。它具有良好的数据完整性和持久性,能够处理大规模的并发访问和复杂的数据操作。MySQL支持灵活的数据模型,可以处理各种类型的数据,并提供了高效的数据读写能力。同时,MySQL还提供了丰富的安全功能,保护敏感数据的安全性。作为一种跨平台的数据库管理系统,MySQL可以在多个操作系统上运行。综上所述,MySQL在Web应用程序、企业级应用、数据分析等领域有广泛的应用,为开发人员提供了强大的数据库管理工具。
Spring Boot是一个简化Java应用程序开发和部署的开源框架。它通过提供约定大于配置的方式,使得开发人员可以更专注于业务逻辑的实现,而无需关注繁琐的配置和集成细节。
Spring Boot具有快速启动的能力,可以在短时间内搭建起一个可运行的应用程序。它自动配置了许多常见的开发环境,如数据库连接、日志记录等,减少了开发人员的配置工作。
Spring Boot采用了简化配置的原则,通过默认配置和自动配置来减少开发人员的配置工作量。开发人员只需要进行少量的配置,即可快速启动应用程序。
Spring Boot内置了多种Web服务器容器,如Tomcat、Jetty等,使得开发人员可以将应用程序打包为可执行的JAR文件,方便地进行部署和分发。
Spring Boot还提供了强大的依赖管理功能,通过自动解决项目所需的依赖库版本冲突和兼容性问题,简化了项目的构建过程。
最后,Spring Boot还提供了丰富的监控和管理功能,如健康检查、指标收集、日志记录等,帮助开发人员更好地理解应用程序的运行状态,并进行故障排查和性能优化。
为了迎合当今社会的现况,便于在市场中打开局面、占有一席之地;在大数据时代下,所有的信息化资源全部都是共享资源、为了长远性考虑,对此需要考虑如何推动整体的系统开发实现标准化。保证系统成功,所以就必须从效益、技术等上面做可行性报告研究。
智能购房推荐系统存储所使用的mysql数据库以及开发中所使用的IDEA、Tomcat这些开发工具的使用,能够给我们的编写工作带来许多的便利。系统使用springboot框架进行开发,使系统的可扩展性和维护性更佳,减少java配置代码,简化编程代码,目前springboot框架也是很多企业选择的框架之一。
在开发智能购房推荐系统中所使用的开发软件像IDEA开发工具、Tomcat8.0服务器、MySQL5.7数据库、Photoshop图片处理软件等,这些都是开源免费的,并且智能购房推荐系统是自己设计并编码实现的,数据库是使用流行mysql进行数据的存储,开源的mysql等技术的使用,减少系统开发费用。
系统从法律层面上来没有对第三方有其他放有法律层面的问题,系统数据库采用的Mysql 开源社区数据库、框架采用的是开源的Spring boot。系统资讯和相关内容也是呵呵法律层面的。在源码的管理上采用git开源进行管理,所以在法律可行性上是成立的。
智能购房推荐系统中采用了Java的springboot框架进行开发,在数据库上选择MYSQL,在功能上智能购房推荐系统我划分为了普通用户管理模块和管理员模块这两大部分。
用户管理模块:
(1)用户注册登录:游客可以随时进入到系统中,对系统中的信息浏览,但是想要实现房源信息的收藏评论等,就必须有这个系统的账号,如果没有账号的话,可以注册成普通用户进行相关的操作,同时用户还可以对个人信息以及操作的信息进行管控。
(2)查看智能购房推荐系统的首页信息:智能购房推荐系统的首页信息包含了首页、房屋资讯、房源信息、需求信息。
(3)通知公告:用户点击“通知公告”菜单显示管理员在后台发布的所有的通知公告信息,可以查看通知公告详情。
(4)房源信息:用户点击“房源信息”菜单可以查看所有房源信息信息,可以按照条件查看房源信息,或者输入关键词进行查询,点击可以进入房源信息详细展示界面,在此界面用户可以收藏、点赞和评论。
(5)我的账户:用户点击“我的账户”可以对个人资料以及密码进行更新。
(6)我的收藏:用户点击“我的收藏”,会显示出自己收藏的所有信息,点击某一条收藏可以查看信息详细介绍,同时删除收藏;
管理员管理模块:
(1)登录:管理员在后台可以输入用户名+密码进行登录,管理员的用户名和密码是在数据库中直接设定好的。
(2)系统用户:管理员点击“系统用户”这一菜单会显示管理员+普通用户这两个子菜单,管理员可以对这两个角色的信息进行增删改查操作。
(3)房源信息:管理员点击“房源信息”这一菜单会所有的房源信息,管理员可以对房源信息进行增删改查操作。
(4)房屋类型:管理员点击“房屋类型”菜单可以对房屋类型进行增删改查。
(5)地区名称:管理员点击“地区名称”菜单可以对地区名称进行增删改查。
(6)需求信息:管理员点击“需求信息”菜单可以对需求信息进行增删改查。
(7)系统管理:管理员点击“系统管理”菜单可以对首页展示的轮播图进行增删改查。
(8)通知公告:管理员点击“通知公告”菜单可以查看到系统中的所有公告信息,对已经存在的公告,管理员可以修改,也可以添加新的公告或者删除公告。
(9)资源管理管理:管理员在后台可以对智能购房推荐系统中显示的房屋资讯以及资讯分类进行增删改查。
智能购房推荐系统的非功能性需求比如智能购房推荐系统的安全性怎么样,可靠性怎么样,性能怎么样,可拓展性怎么样等。具体可以表示在如下3-1表格中:
表3-1智能购房推荐系统非功能需求表
安全性 | 主要指智能购房推荐系统数据库的安装,数据库的使用和密码的设定必须合乎规范。 |
可靠性 | 可靠性是指智能购房推荐系统能够安装用户的指示进行操作,经过测试,可靠性90%以上。 |
性能 | 性能是影响智能购房推荐系统占据市场的必要条件,所以性能最好要佳才好。 |
可扩展性 | 比如数据库预留多个属性,比如接口的使用等确保了系统的非功能性需求。 |
易用性 | 用户只要跟着智能购房推荐系统的页面展示内容进行操作,就可以了。 |
可维护性 | 智能购房推荐系统开发的可维护性是非常重要的,经过测试,可维护性没有问题 |
通过3-1功能的分析,得出了本智能购房推荐系统的用例图:
普通用户角色用例如图3-1所示。
图3-1 智能购房推荐系统普通用户角色用例图
web后台管理上的管理员是维护整个智能购房推荐系统中所有数据信息的。管理员角色用例如图3-2所示。
图3-2 智能购房推荐系统管理员角色用例图
在上一章节中主要对系统的功能性需求和非功能性需求进行分析,并且根据需求分析了本智能购房推荐系统中的用例。那么接下来就要开始对本智能购房推荐系统的架构、主要功能和数据库开始进行设计。智能购房推荐系统根据前面章节的需求分析得出,其总体设计模块图如图4-1所示。
图4-1 系统功能结构图
在需求分析中,我们用来分析的对象往往是抽象的概念,所以在这个环节应当避免过于细致的细节分析,而是通过这些抽象的概念来分析实体所具备的属性和实体之间的联系。智能购房推荐系统利用E-R图对上述实体和联系进行描述。
系统的主要实体间关系E-R图如下图所示。
图4-2 系统E-R图
数据库是智能购房推荐系统的数据处理的基础,也是为界面数据的展示与存储的关键。智能购房推荐系统的数据库表如下。
表comment (评论)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | comment_id | int | 10 | 0 | N | Y | 评论ID: | |
2 | user_id | int | 10 | 0 | N | N | 0 | 评论人ID: |
3 | reply_to_id | int | 10 | 0 | N | N | 0 | 回复评论ID:空为0 |
4 | content | longtext | 2147483647 | 0 | Y | N | 内容: | |
5 | nickname | varchar | 255 | 0 | Y | N | 昵称: | |
6 | avatar | varchar | 255 | 0 | Y | N | 头像地址:[0,255] | |
7 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
8 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
9 | source_table | varchar | 255 | 0 | Y | N | 来源表: | |
10 | source_field | varchar | 255 | 0 | Y | N | 来源字段: | |
11 | source_id | int | 10 | 0 | N | N | 0 | 来源ID: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | house_type_id | int | 10 | 0 | N | Y | 房屋类型ID | |
2 | house_type | varchar | 64 | 0 | Y | N | 房屋类型 | |
3 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
4 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | notice_id | mediumint | 8 | 0 | N | Y | 公告id: | |
2 | title | varchar | 125 | 0 | N | N | 标题: | |
3 | content | longtext | 2147483647 | 0 | Y | N | 正文: | |
4 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
5 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | praise_id | int | 10 | 0 | N | Y | 点赞ID: | |
2 | user_id | int | 10 | 0 | N | N | 0 | 点赞人: |
3 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
4 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
5 | source_table | varchar | 255 | 0 | Y | N | 来源表: | |
6 | source_field | varchar | 255 | 0 | Y | N | 来源字段: | |
7 | source_id | int | 10 | 0 | N | N | 0 | 来源ID: |
8 | status | bit | 1 | 0 | N | N | 1 | 点赞状态:1为点赞,0已取消 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | property_information_id | int | 10 | 0 | N | Y | 房源信息ID | |
2 | region_name | varchar | 64 | 0 | Y | N | 地区名称 | |
3 | house_name | varchar | 64 | 0 | Y | N | 房屋名称 | |
4 | house_type | varchar | 64 | 0 | Y | N | 房屋类型 | |
5 | housing_area | varchar | 64 | 0 | Y | N | 房屋面积 | |
6 | house_orientation | varchar | 64 | 0 | Y | N | 房屋朝向 | |
7 | house_prices | varchar | 64 | 0 | Y | N | 房屋价格 | |
8 | house_address | varchar | 64 | 0 | Y | N | 房屋地址 | |
9 | house_pictures | varchar | 255 | 0 | Y | N | 房屋图片 | |
10 | introduction_to_the_house | longtext | 2147483647 | 0 | Y | N | 房屋介绍 | |
11 | hits | int | 10 | 0 | N | N | 0 | 点击数 |
12 | praise_len | int | 10 | 0 | N | N | 0 | 点赞数 |
13 | recommend | int | 10 | 0 | N | N | 0 | 智能推荐 |
14 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
15 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | region_name_id | int | 10 | 0 | N | Y | 地区名称ID | |
2 | region_name | varchar | 64 | 0 | Y | N | 地区名称 | |
3 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
4 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | regular_users_id | int | 10 | 0 | N | Y | 普通用户ID | |
2 | user_name | varchar | 64 | 0 | Y | N | 用户姓名 | |
3 | user_gender | varchar | 64 | 0 | Y | N | 用户性别 | |
4 | contact_phone_number | varchar | 16 | 0 | Y | N | 联系电话 | |
5 | examine_state | varchar | 16 | 0 | N | N | 已通过 | 审核状态 |
6 | user_id | int | 10 | 0 | N | N | 0 | 用户ID |
7 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
8 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
表requirement_information (需求信息)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | requirement_information_id | int | 10 | 0 | N | Y | 需求信息ID | |
2 | requirement_title | varchar | 64 | 0 | Y | N | 需求标题 | |
3 | user_information | int | 10 | 0 | Y | N | 0 | 用户信息 |
4 | user_name | varchar | 64 | 0 | Y | N | 用户姓名 | |
5 | contact_phone_number | varchar | 64 | 0 | Y | N | 联系电话 | |
6 | requirement_content | text | 65535 | 0 | Y | N | 需求内容 | |
7 | requirement_remarks | text | 65535 | 0 | Y | N | 需求备注 | |
8 | examine_state | varchar | 16 | 0 | N | N | 未审核 | 审核状态 |
9 | examine_reply | varchar | 16 | 0 | Y | N | 审核回复 | |
10 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
11 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | sensitive_vocabulary_id | int | 10 | 0 | N | Y | 敏感词汇ID | |
2 | sensitive_vocabulary | varchar | 64 | 0 | Y | N | 敏感词汇 | |
3 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
4 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | slides_id | int | 10 | 0 | N | Y | 轮播图ID: | |
2 | title | varchar | 64 | 0 | Y | N | 标题: | |
3 | content | varchar | 255 | 0 | Y | N | 内容: | |
4 | url | varchar | 255 | 0 | Y | N | 链接: | |
5 | img | varchar | 255 | 0 | Y | N | 轮播图: | |
6 | hits | int | 10 | 0 | N | N | 0 | 点击量: |
7 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
8 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | upload_id | int | 10 | 0 | N | Y | 上传ID | |
2 | name | varchar | 64 | 0 | Y | N | 文件名 | |
3 | path | varchar | 255 | 0 | Y | N | 访问路径 | |
4 | file | varchar | 255 | 0 | Y | N | 文件路径 | |
5 | display | varchar | 255 | 0 | Y | N | 显示顺序 | |
6 | father_id | int | 10 | 0 | Y | N | 0 | 父级ID |
7 | dir | varchar | 255 | 0 | Y | N | 文件夹 | |
8 | type | varchar | 32 | 0 | Y | N | 文件类型 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | user_id | mediumint | 8 | 0 | N | Y | 用户ID:[0,8388607]用户获取其他与用户相关的数据 | |
2 | state | smallint | 5 | 0 | N | N | 1 | 账户状态:[0,10](1可用|2异常|3已冻结|4已注销) |
3 | user_group | varchar | 32 | 0 | Y | N | 所在用户组:[0,32767]决定用户身份和权限 | |
4 | login_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 上次登录时间: |
5 | phone | varchar | 11 | 0 | Y | N | 手机号码:[0,11]用户的手机号码,用于找回密码时或登录时 | |
6 | phone_state | smallint | 5 | 0 | N | N | 0 | 手机认证:[0,1](0未认证|1审核中|2已认证) |
7 | username | varchar | 16 | 0 | N | N | 用户名:[0,16]用户登录时所用的账户名称 | |
8 | nickname | varchar | 16 | 0 | Y | N | 昵称:[0,16] | |
9 | password | varchar | 64 | 0 | N | N | 密码:[0,32]用户登录所需的密码,由6-16位数字或英文组成 | |
10 | | varchar | 64 | 0 | Y | N | 邮箱:[0,64]用户的邮箱,用于找回密码时或登录时 | |
11 | email_state | smallint | 5 | 0 | N | N | 0 | 邮箱认证:[0,1](0未认证|1审核中|2已认证) |
12 | avatar | varchar | 255 | 0 | Y | N | 头像地址:[0,255] | |
13 | open_id | varchar | 255 | 0 | Y | N | 针对获取用户信息字段 | |
14 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
15 | vip_level | varchar | 255 | 0 | Y | N | 会员等级 | |
16 | vip_discount | double | 11 | 2 | Y | N | 0.00 | 会员折扣 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | group_id | mediumint | 8 | 0 | N | Y | 用户组ID:[0,8388607] | |
2 | display | smallint | 5 | 0 | N | N | 100 | 显示顺序:[0,1000] |
3 | name | varchar | 16 | 0 | N | N | 名称:[0,16] | |
4 | description | varchar | 255 | 0 | Y | N | 描述:[0,255]描述该用户组的特点或权限范围 | |
5 | source_table | varchar | 255 | 0 | Y | N | 来源表: | |
6 | source_field | varchar | 255 | 0 | Y | N | 来源字段: | |
7 | source_id | int | 10 | 0 | N | N | 0 | 来源ID: |
8 | register | smallint | 5 | 0 | Y | N | 0 | 注册位置: |
9 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
10 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
登录的验证将不再局限于登录信息和权限的匹配验证,而是另外增加了一个验证码,只有界面上所有的编辑框数据都准确的情况下才能实现登录成功。管理员的登录和前台用户登录是一样的过程,其主要就是利用权限字段来完成对用户或管理员的角色识别。
登录流程图如下所示。
图5-1 登录流程
系统登录界面如下图所示。
图5-2 系统登录界面
登录关键代码如下:
注册的本质是后台拿到前台的数据,使用的方法是request.getParameter方法,然后拿到的数据再封装到会员实体类中,保存到数据库中。值得注意的是,注册的时候是需要输入合法的字符的,不合法那么则会进行红色报错,这个功能的实现是通过validate框架实现的,本质是封装好了的正则表达式。
用户注册流程图如下所示。
图5-4 用户注册流程
用户注册界面如下图所示。
图5-5 用户注册界面
注册关键代码如下:
用户使用该智能购房推荐系统 注册完成后,用户对登录密码有修改需求时,系统也可以提供用户修改密码权限。系统中所有的操作者能够变更自己的密码信息,执行该功能首先必须要登入系统,然后选择密码变更选项以后在给定的文本框中填写初始密码和新密码来完成修改密码的操作。在填写的时候,假如两次密码填写存在差异,那么此次密码变更操作失败,下面的图片展示的就是该板块对应的工作面。
密码修改流程图如下所示。
图5-6 密码修改流程图
密码修改界面如图所示。
图5-7 密码修改界面
密码修改关键代码如下:
用户选择相应的房源收藏,通过id传参,找到id为此传参的房源,在收藏页提交收藏记录表单,生成收藏记录,用户在个人中心管理个人的收藏夹。
房源收藏界面如下图所示。
图5-9 房源信息界面
用户执行需求信息,并可以操作相关内容,例如查看,编辑。需求信息的添加操作是建立在需求信息的列表基础上,单击查需求信息下的需求信息链接;然后单击“需求信息”进行添加,添加成功后的信息会载入到需求信息查询列表中。
需求信息流程图如下所示。
图5-10 需求信息流程图
需求信息界面如下图所示。
图5-11 需求信息界面
用户登录成功后,进入到管理系统的主页,主页整体通过html技术实现。主页主要包括初始显示的首页和左侧的菜单栏,菜单栏又包括用户管理、房源信息管理、房屋类型管理、地区名称管理、需求信息管理、系统管理、通知公告管理、资源管理等多个一级菜单,每一种一级菜单又对应着很多种二级目录,单击右侧即可显示页面内容。
智能购房推荐系统主页界面如下图示。
图5-12 主页界面
注册用户信息,用户通过注册了方可获得其对智能购房推荐系统的登录使用权限,此时选择注册用户选项,系统就会自动转到用户注册工作面,在注册该部分信息时系统会自动调用add函数,然后在给定的文本框中填写有关该用户的基础信息后选择确认即可完成注册。检索用户信息,在新增用户信息以后,在检索工具栏中填写对应的用户信息,系统就会将该用户有关的所有信息展示出来。
用户管理界面如下图所示。
图5-13 用户管理界面
用户管理关键代码如下:
在主页左侧菜单栏中点击“房源管理”按钮,再从二级目录中点击“新增房源”按钮,进入到新增房源界面。在此处房源可以添加房源的地区名称、房屋名称、房屋类型、房屋面积、房屋朝向、房屋价格、房屋地址。
在主页左侧菜单栏中点击“房源管理”按钮,再从二级目录中点击“查询房源”按钮,进入到查询房源界面。在此处房源可以查询当前所有房源记录。
房源管理流程如下图所示。
图5-14 房源管理流程
房源管理的界面如所示。
图5-15 房源管理界面
房源管理关键如下:
-
-
- 需求信息管理模块
-
需求信息管理包括新增需求信息、删除需求信息、修改需求信息、查询需求信息等,以需求信息新增为例,在视图层请求需求信息新增,反馈后,调用业务逻辑层,通过业务逻辑层的接口调用底层的数据逻辑层完成数据库联动操作。
需求信息管理的流程如所示。
图5-16 需求信息管理流程
需求信息管理的界面如所示。
图5-17 需求信息管理界面
需求信息管理关键如下:
系统测试的目的在于尽可能多地检测系统中存在的bug或错误。由于系统是由人开发而成,所以不可避免地会因算法等各种原因出现问题。因此,及早发现这些问题并在系统上线之前解决是非常重要的。为了达到这个目的,需要对系统进行测试。
本文主要针对系统进行了兼容性测试,并使用了典型的测试用例。兼容性测试是一种验证系统是否能够在不同的环境和配置下正常工作的测试方法。通过对不同操作系统、浏览器版本、设备等进行测试,可以确保系统具备广泛的兼容性,能够满足用户在不同平台上的需求。
在测试过程中,我们采用了一系列典型的测试用例。测试用例是一组旨在验证系统功能和性能的输入、执行步骤和预期结果的集合。通过使用典型的测试用例,我们能够覆盖系统的各个方面,并确保系统在各种情况下都能正确运行。
浏览器兼容性问题:随着ES6标准的制定,现在主流的浏览器大多符合ES6标准。尤其是以谷歌为核心的内核浏览器,它们对ES6标准的支持较好。然而,早期版本的IE浏览器使用了微软自家的内核,对兼容性产生了一些影响。经过测试,目前的主要浏览器包括谷歌、IE、360和火狐等最新版本的运行没有问题,状态良好。只有早期版本的IE可能会出现图片展示问题,但通过对代码的修改已经得到了改善。因此,总体来说,浏览器兼容性没有问题。
JDK、Tomcat等兼容性问题:本项目使用的JDK版本是1.8,自动搭配的Tomcat版本是9.0,MySQL版本是5.5。经过尝试,我们发现可以使用1.7以上的JDK版本,但1.7以下的版本不兼容。如果遇到MySQL版本冲突,需要修改配置文件中的类信息。至于Tomcat的兼容性较好,8版本以上都是兼容的。
登录测试用例如下表所示。
表6-1 登录测试用例
测试用例编号 | YL_01 | |
测试用例名称 | 系统使用者登录 | |
测试用例描述 | 登录者输入用户名、密码和验证码 | |
系统入口 | 浏览器 | |
步骤 | 预期结果 | 实际结果 |
输入正确的用户名、密码和验证码 | 提示“登录成功”,并进入系统 | 预期结果 |
输入错误的用户名、密码和验证码 | 提示“登录失败”,并返回登录界面 | 预期结果 |
不输入用户名、密码和验证码 | 提示“请输入完整” | 预期结果 |
注册测试用例如下表所示。
表6-2 注册测试用例
测试用例编号 | YL_02 | |
测试用例名称 | 系统使用者注册账号 | |
测试用例描述 | 使用者输入用户名、密码以及个人信息进行账号注册 | |
系统入口 | 浏览器 | |
步骤 | 预期结果 | 实际结果 |
输入系统不存在的用户名、密码和个人信息 | 提示“注册成功” | 预期结果 |
输入系统已存在的用户名 | 提示“注册失败”,并返回注册界面 | 预期结果 |
不输入用户名、密码和个人信息 | 提示“请输入完整” | 预期结果 |
-
-
- 新增资讯测试
-
新增资讯测试用例如下表所示。
表6-4 新增资讯测试用例
测试用例编号 | YL_04 | |
测试用例名称 | 系统使用者进行新增资讯 | |
测试用例描述 | 使用者输入资讯标题、内容等信息 | |
系统入口 | 浏览器 | |
步骤 | 预期结果 | 实际结果 |
输入完整的资讯标题和内容 | 提示“新增成功”,并进入系统 | 预期结果 |
不输入的资讯标题和内容 | 提示“请输入完整” | 预期结果 |
在系统中,创建功能也是基础功能之一,因此创建功能的测试很有代表性。在此章节主要列举在创建时各种情况下系统结果的测试。由于系统涉及创建功能操作过多,因此将多处统称创建功能。
创建房源用例如下表所示。
表6-5 创建房源测试用例
测试用例编号 | YL_05 | |
测试用例名称 | 系统使用者进行创建房源 | |
测试用例描述 | 使用者输入要创建的房源 | |
系统入口 | 浏览器 | |
步骤 | 预期结果 | 实际结果 |
输入完整并且格式正确的房源 | 提示“创建成功”,并显示所有房源 | 预期结果 |
核心位置房源但非必要位置不输入房源 | 提示“创建成功”,并显示所有房源 | 预期结果 |
核心房源位置不输入房源 | 提示“创建失败” | 预期结果 |
在本次测试的过程主要针对所有功能下的添加操作,修改操作和删除操作,并以真实数据一一进行相关功能项目的输入,最终能够保证每个项目涉及的功能都是能够正常运行,因此能够保证本次设计的,已实现的功能能够正常运行并且相关数据库的信息也同样保证正确。
在开发智能购房推荐系统之前,需要对用户的需求进行详细分析。这包括对系统的可行性、功能需求和其他需求等方面进行分析。在可行性分析阶段,我们对系统的技术实现、经济效益和管理等进行了评估,并得出系统实施的可行性。
本文总结了智能购房推荐系统的背景和现状,然后详细阐述了系统的业务需求。根据这些需求,我们对系统的结构和功能模块进行了详细设计,将系统划分为多个不同的模块。在分析系统功能需求时,我们对整个系统的总体架构和功能模块进行了分析,并选择了适合的系统开发技术来完成各个模块的开发工作。开发完成后,我们对系统进行了部署,并进行了系统测试。测试结果表明,系统在功能和性能等方面都达到了预期要求,具有较高的稳定性和可靠性。
参考文献
[1]刘峰,李安,何勇平等. 一种基于SpringBoot框架的公共资源交易数据交互系统[P]. 广西壮族自治区: CN117474672A, 2024-01-30.
[2]叶志强. 基于java语言切换网点的自动化方法、设备及介质[P]. 上海市: CN117421135A, 2024-01-19.
[3]谭光兴,甘景,戚秋晨. 基于Java语言的远程数据采集系统设计与实现 [J]. 科技与创新, 2024, (01): 19-22.
[4]吴昊,张丹. 基于SpringBoot框架的大学生网上兼职系统设计与实现 [J]. 电脑知识与技术, 2023, 19 (35): 68-72.
[5]马庆. 计算机软件开发中JAVA编程语言的应用 [J]. 山西电子技术, 2023, (06): 84-86+98.
[6]刘明,杨胜飞,张冶锋等. 基于SpringBoot框架的长距离输水工程水量监测系统设计 [J]. 云南水力发电, 2023, 39 (11): 359-362.
[7]Liang C . School Vehicle Management System Based on JAVA Language [J]. Academic Journal of Computing & Information Science, 2023, 6 (9):
[8]刘中林. 基于大数据技术的购房推荐系统的设计与实现[D]. 西安石油大学, 2022.
[9]熊永汪. 一种适应不同购房者需求的推荐系统算法[P]. 广东省: CN114529357A, 2022-05-24.
[10]刘中林,郑凯东. 基于大数据技术的购房推荐系统的设计与实现 [J]. 信息与电脑(理论版), 2022, 34 (07): 190-193.
[11]高志平. 基于SpringBoot框架与ITIL方法的运维管理系统的设计与实现[D]. 华东师范大学, 2021.
[12]夏健强, 基于Java语言的在线网络视频聊天系统V1.0. 湖北省, 武汉东湖学院, 2021-11-01.
[13]樊璐,胡腾云,韩萍. 基于购房资格核验的购房推荐装置及方法[P]. 北京市: CN113052727A, 2021-06-29.
[14]Liu S . Explore Java Language and Android Mobile Software Development [J]. International Journal of Frontiers in Engineering Technology, 2021, 3.0 (2.0):
[15]施珺,纪兆辉,赵雪峰. Java语言实验与课程设计指导[M]. 南京大学出版社: 202101. 304.
[16]Kline K . The Java Language Extension for SQL Server Is Now Open Source [J]. Database Trends and Applications, 2020, 34 (4): 31-31.
致谢
程序的开发与设计是对我大学多年中所学知识的一个整体的运用的一个考验,从最开始拿到论题时的不知所措,再上网找资料,参考成熟的智能购房推荐系统,向老师寻求帮助,最后和同学一起讨论,把面前的一座座大山一一翻越。通过对本次论文的开发与设计,我发现了还有很多知识撑握的不牢固,而且经常会有一些低级错,如果说出来,都会好笑,通过实践发现了很多问题,正是这些问题帮助我找到需要学习的方向,也希望同学、老师够给我更多的帮助。
首先我要感谢我的指导老师,在教学任务繁忙的情况下,任然抽出很多的时间帮助我纠正我在系统设计当中出现的不严谨的地方,在程序即将设计完成之后又开始为我的论文进行校正,是他辛苦付出才使得我们的毕业设计高质量完成。
最后要感谢我的同学,在我心情糟糕的时候逗我开心,在我压力大的时候陪我放松,在我对现在迷茫抱怨的时候让我觉得未来可期。感谢他对我的鼓励和陪伴,我才一路坚持下来,谢谢你。