摘 要
随着旅游业的快速发展,旅游目的地的特色推荐系统变得愈发重要。本研究以湛江市为背景,基于Spring Boot框架,设计并实现了一套湛江特色推荐系统,包括首页、通知公告、湛江文化、留言反馈、景点信息、美食推荐和酒店推荐等模块。通过对用户兴趣和偏好的分析,系统能够向用户推荐与湛江特色相关的旅游景点、文化特色、美食佳肴和酒店住宿,提升用户的旅游体验和满意度。
湛江市地处中国南海沿岸,拥有丰富的海洋资源和独特的地域文化,旅游资源十分丰富。然而,传统的旅游推荐方式往往无法充分满足游客个性化、多样化的需求,因此设计一个基于个性化推荐的特色旅游推荐系统具有重要意义。基于此背景,本研究旨在结合Spring Boot框架的开发特性,构建一套湛江特色推荐系统,通过个性化推荐算法,为游客提供更加贴合其兴趣和需求的湛江旅游推荐服务,推动湛江旅游业的智慧化发展。
关键词:JAVA语言;SpringBoot框架;MYSQL数据库
Abstract
With the rapid development of the tourism industry, the feature recommendation system for tourist destinations has become increasingly important. This study takes Zhanjiang City as the background and designs and implements a Zhanjiang characteristic recommendation system based on the Spring Boot framework, including modules such as homepage, notification announcement, Zhanjiang culture, message feedback, scenic spot information, food recommendation, and hotel recommendation. By analyzing user interests and preferences, the system can recommend tourist attractions, cultural features, delicious food, and hotel accommodations related to the characteristics of Zhanjiang to users, improving their travel experience and satisfaction.
Zhanjiang City is located along the coast of the South China Sea, with abundant marine resources and unique regional culture, and abundant tourism resources. However, traditional tourism recommendation methods often cannot fully meet the personalized and diverse needs of tourists. Therefore, designing a personalized recommendation based characteristic tourism recommendation system is of great significance. Based on this background, this study aims to combine the development characteristics of the Spring Boot framework to construct a Zhanjiang characteristic recommendation system. Through personalized recommendation algorithms, it provides tourists with Zhanjiang tourism recommendation services that are more in line with their interests and needs, promoting the intelligent development of Zhanjiang's tourism industry.
Keywords: JAVA language; SpringBoot framework; MYSQL database
- 1 章 绪 论
- 选题背景与意义
基于springboot湛江特色推荐系统设计与实现,现如今随着城市化进程的加快,人们对生活品质的需求逐渐增加。湛江特色融合了自然风光、乡土文化和乡村生活体验,为游客提供了一种别具特色的旅游选择。然而,传统的湛江文化服务往往存在着信息不对称、预订不便等问题,制约了湛江文化的发展。设计并实现一个基于微信小程序的湛江特色推荐系统具有重要意义。这样的平台可以为游客提供便捷的预订服务、详细的景点、民宿和餐饮信息、以及个性化的旅游攻略和导航服务,从而促进湛江文化资源的开发与利用,提升湛江文化服务的质量,推动湛江文化产业的发展。因此,本研究对于促进湛江文化产业的数字化转型,提升湛江文化服务水平具有重要的现实意义。
湛江市作为一个具有丰富海洋资源和独特地域文化的旅游目的地,其旅游业发展迅速。然而,传统的旅游推荐方式存在着信息不够精准、个性化程度不高的问题。目前,国内外学者和工程师们对于旅游推荐系统的研究与实践愈发活跃,个性化推荐技术逐渐成为旅游行业关注的焦点。
在国内外,许多研究机构和高校围绕旅游推荐系统展开了深入研究。个性化推荐算法如基于内容的推荐、协同过滤推荐、深度学习推荐等得到了广泛应用,并在不同领域取得了显著效果。同时,结合地理位置信息和用户历史行为数据的推荐系统设计也日益受到关注,为用户提供更加精准的推荐服务。
特色旅游推荐系统的设计与实现已成为学术界和产业界的研究热点。针对不同地区和城市的特色旅游资源,研究者们提出了许多创新性的推荐系统方案,以期提升游客的旅游体验和满意度。然而,针对湛江市特色旅游资源的个性化推荐系统研究尚属较少,因此本研究的开展具有一定的创新性和实践意义。通过结合Spring Boot框架的特性,本研究将探索一种适用于湛江市特色旅游推荐的系统设计与实现方案,为湛江市的旅游业发展提供新的思路和方法。
论文将分层次经行编排,除去论文摘要致谢文献参考部分,正文部分还会对系统需求做出分析,以及阐述大体的设计和实现的功能,最后罗列部分调测记录,论文主要架构如下:
第一章:引言。第一章主要介绍了课题研究的背景和意义,系统开发的国内外研究现状和本文的研究内容与主要工作。
第二章:系统需求分析。主要从系统的用户、功能等方面进行需求分析。
第三章:系统设计。主要对系统框架、系统功能模块、数据库进行功能设计。
第四章:系统实现。主要介绍了系统框架搭建、系统界面的实现。
第五章:系统测试。主要对系统的部分界面进行测试并对主要功能进行测试
第六章:总结。
- 2 章 系统的需求分析
需求分析是开发一个系统之前首先要做的,如果一个系统不值得开发或者违反了相关法律法规,那么开发出来的系统将一文不值,所以在开发之前,我们首先要对系统的需求进行分析,分析系统开发是否可行,如果可行的话,再具体分析用户的需求,分析出系统的功能以及对系统的性能进行分析。
基于Spring Boot框架的湛江特色推荐系统具有较高的技术可行性。Spring Boot作为成熟稳定的Java后端框架,支持大规模用户访问,能够整合个性化推荐算法,处理地理位置信息,并提供数据安全与隐私保护。同时,Spring Boot与现代前端框架无缝整合,能够满足系统的稳定性、性能需求和个性化推荐算法的实现,有望为湛江市的旅游业发展提供强大的技术支持。
经济方面的可行性主要考虑的是成本以及效益,从成本方面看,开发过程中使用的JAVA、SpringBoot、MYSQL等都可以通过网上搜索下载,没有任何费用,开发的成本几乎不存在;从效益方面看,系统的完成能够给用户提供支持,降低企业的成本,提高管理的效率,因此在经济上也是没有问题的。
法律方面主要考虑的是系统的开发是否违法,开发的湛江特色推荐系统严格按照《中华人民共和国计算机软件保护条例》、《中华人民共和国著作权法》等法律法规,系统的开发可以为当地旅游业带来收益,不存在违法行为,因此在法律上是可行的。
操作方面主要考虑的是用户在使用以及管理人员在管理的时候,是否简单可行,没有任何计算机基础的用户能否使用,开发的湛江特色推荐系统在设计的时候秉承简单易学的理念,在用户进入系统后都会有固定的导航按钮,只要认字就可以操作完成,而且管理员也只需简单的增删改查即可完成,因此在操作上也是可行的。
总的来看,开发的湛江特色推荐系统在可行性方面是没有问题的,值得开发,而且其他的完成对行业发展来说具有重大意义。
湛江特色推荐系统为普通用户提供了全面的湛江特色信息查询、景点信息、美食推荐和酒店推荐功能,同时管理员可以方便地管理网站的各项内容和功能。这样的功能设置将为用户提供便捷的旅游服务,并为湛江特色推荐系统搭建一个全面而高效的在线平台。系统功能需求分析主要包括两大模块:普通用户模块和管理员模块。
(1)普通用户模块功能需求:
用户注册与登录
允许用户注册账户,并提供登录功能,确保用户身份识别和安全访问。
个人资料管理
提供用户个人资料编辑功能,包括头像上传、个人信息修改等。
景点信息浏览与搜索
允许用户浏览湛江特色景点信息,包括文字介绍、图片展示等,并提供搜索功能,便于用户查找感兴趣的景点。
美食推荐浏览
提供湛江特色美食的推荐展示,包括美食介绍、推荐指数等,方便用户了解当地美食文化。
酒店推荐浏览
提供湛江地区的酒店推荐信息,包括酒店位置、价格、设施等,帮助用户选择合适的住宿地点。
留言反馈
允许用户对景点、美食、酒店等进行评论和留言,提供用户交流和反馈的平台。
- 管理员模块功能需求:
管理员登录与权限管理
管理员账户登录系统后,具有管理权限,包括用户管理、景点信息管理、美食推荐管理、酒店推荐管理等。
用户管理
管理员可以对用户信息进行管理,包括审核注册信息、处理投诉等。
景点信息管理
管理员可以管理景点信息的发布、修改和删除,确保信息的准确性和时效性。
美食推荐管理
管理员可以管理美食推荐信息,包括推荐指数的设置、推荐内容的编辑等。
酒店推荐管理
管理员可以对用户信息进行管理,包括审核注册信息、处理投诉等。
通知公告发布
管理员可以发布系统通知公告,包括活动信息、重要通知等,向用户传达相关信息。
以上功能需求分析旨在确保普通用户和管理员用户在系统中能够进行相关的操作,达到信息的发布、管理和用户体验的提升。
湛江特色推荐系统的性能性需求分析主要是分析本系统的安全性怎么样(是否会泄露用户个人信息),可靠性怎么样(用户操作的时候是不是能够根据实际操作显示信息),性能怎么样(运行是否操作流畅),可拓展性怎么样(功能能否继续拓展)等。具体可以表示在如下2.1表格中:
表2.1 湛江特色推荐系统非功能需求表
安全性 | 主要指湛江特色推荐系统数据库的安装,数据库的使用和密码的设定必须合乎规范。 |
可靠性 | 可靠性是指湛江特色推荐系统能够按照用户的指示进行操作,经过测试,可靠性90%以上。 |
性能 | 性能是影响湛江特色推荐系统占据市场的必要条件,所以性能最好要佳才好。 |
可扩展性 | 比如数据库预留多个属性,比如接口的使用等确保了系统的非功能性需求。 |
易用性 | 用户只要跟着湛江特色推荐系统的页面展示内容进行操作,就可以了。 |
可维护性 | 湛江特色推荐系统开发的可维护性是非常重要的,经过测试,可维护性没有问题 |
湛江特色推荐系统为普通用户提供了全面的旅游信息查询、景点购票和酒店预订等功能。用户的用例图如下图2-1所示:
图2-1 普通用户角色用例图
图2-2 管理员角色用例图
系统中的所有用户(管理员和普通用户)都可以实现增加数据功能,图2-3显示的就是在增加数据时的流程。
图2-3增加数据流程图
人无完人,每个人都有出错的时候,在录入系统信息的时候如果信息有错,可以对系统中的数据进行编辑。图2-4显示的就是修改数据的流程。
图2-4修改数据流程图
在系统中经常会出现一些过期的数据,比如用户注销等,那就可以直接删除这些数据,图2-5就是删除数据时的流程图。
图2-5删除数据流程图
分析完系统的可行性以及功能,接下来就是对系统具体的设计,通过可行性分析我们得出系统是值得开发的,通过功能分析我们可以得出系统具体实现了哪些功能,然后根据功能需求完成系统的功能设计,本章从功能模块以及系统的数据库两个方面进行介绍。
通过上一章节的功能需求分析,可以得出本湛江特色推荐系统的功能结构图,图3-1就是系统的功能模块图。
图3-1 湛江特色推荐系统功能模块图
数据库的设计是一个系统的基础,不管什么系统,界面设计的再美观,如果没有一个强大的数据库进行支撑,那也没有办法运行,在设计数据库的时候我们首先对数据库进行分析,然后进行概念模型设计,最后建立数据库表,具体展示如下。
在数据库概念模型设计的时候,一般都采用E-R实体图进行展示,在实体图中可以展示出数据库表中的所有字段名称,本系统中的主要的数据库总E-R模型图如下图所示。
图3-2 湛江特色推荐系统总E-R关系图
在数据库表中我们会看到系统的表名、主键、外键等信息,我们通过数据库表的主键、外键把每个表关联起来,然后在界面中展示,本湛江特色推荐系统的主要的数据库表如下:
表access_token (登陆访问时长)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | token_id | int | 10 | 0 | N | Y | 临时访问牌ID | |
2 | token | varchar | 64 | 0 | Y | N | 临时访问牌 | |
3 | info | text | 65535 | 0 | Y | N | ||
4 | maxage | int | 10 | 0 | N | N | 2 | 最大寿命:默认2小时 |
5 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
6 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
7 | user_id | int | 10 | 0 | N | N | 0 | 用户编号: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | article_id | mediumint | 8 | 0 | N | Y | 文章id:[0,8388607] | |
2 | title | varchar | 125 | 0 | N | Y | 标题:[0,125]用于文章和html的title标签中 | |
3 | type | varchar | 64 | 0 | N | N | 0 | 文章分类:[0,1000]用来搜索指定类型的文章 |
4 | hits | int | 10 | 0 | N | N | 0 | 点击数:[0,1000000000]访问这篇文章的人次 |
5 | praise_len | int | 10 | 0 | N | N | 0 | 点赞数 |
6 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
7 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
8 | source | varchar | 255 | 0 | Y | N | 来源:[0,255]文章的出处 | |
9 | url | varchar | 255 | 0 | Y | N | 来源地址:[0,255]用于跳转到发布该文章的网站 | |
10 | tag | varchar | 255 | 0 | Y | N | 标签:[0,255]用于标注文章所属相关内容,多个标签用空格隔开 | |
11 | content | longtext | 2147483647 | 0 | Y | N | 正文:文章的主体内容 | |
12 | img | varchar | 255 | 0 | Y | N | 封面图 | |
13 | description | text | 65535 | 0 | Y | N | 文章描述 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | type_id | smallint | 5 | 0 | N | Y | 分类ID:[0,10000] | |
2 | display | smallint | 5 | 0 | N | N | 100 | 显示顺序:[0,1000]决定分类显示的先后顺序 |
3 | name | varchar | 16 | 0 | N | N | 分类名称:[2,16] | |
4 | father_id | smallint | 5 | 0 | N | N | 0 | 上级分类ID:[0,32767] |
5 | description | varchar | 255 | 0 | Y | N | 描述:[0,255]描述该分类的作用 | |
6 | icon | text | 65535 | 0 | Y | N | 分类图标: | |
7 | url | varchar | 255 | 0 | Y | N | 外链地址:[0,255]如果该分类是跳转到其他网站的情况下,就在该URL上设置 | |
8 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
9 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
表attraction_information (景点信息)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | attraction_information_id | int | 10 | 0 | N | Y | 景点信息ID | |
2 | attraction_name | varchar | 64 | 0 | Y | N | 景点名称 | |
3 | types_of_attractions | varchar | 64 | 0 | Y | N | 景点类型 | |
4 | scenic_spot_pictures | varchar | 255 | 0 | Y | N | 景点图片 | |
5 | attraction_tickets | int | 10 | 0 | Y | N | 0 | 景点门票 |
6 | location_of_tourist_attractions | varchar | 64 | 0 | Y | N | 景点位置 | |
7 | introduction_to_scenic_spots | text | 65535 | 0 | Y | N | 景点介绍 | |
8 | hits | int | 10 | 0 | N | N | 0 | 点击数 |
9 | praise_len | int | 10 | 0 | N | N | 0 | 点赞数 |
10 | recommend | int | 10 | 0 | N | N | 0 | 智能推荐 |
11 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
12 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | auth_id | int | 10 | 0 | N | Y | 授权ID: | |
2 | user_group | varchar | 64 | 0 | Y | N | 用户组: | |
3 | mod_name | varchar | 64 | 0 | Y | N | 模块名: | |
4 | table_name | varchar | 64 | 0 | Y | N | 表名: | |
5 | page_title | varchar | 255 | 0 | Y | N | 页面标题: | |
6 | path | varchar | 255 | 0 | Y | N | 路由路径: | |
7 | position | varchar | 32 | 0 | Y | N | 位置: | |
8 | mode | varchar | 32 | 0 | N | N | _blank | 跳转方式: |
9 | add | tinyint | 3 | 0 | N | N | 1 | 是否可增加: |
10 | del | tinyint | 3 | 0 | N | N | 1 | 是否可删除: |
11 | set | tinyint | 3 | 0 | N | N | 1 | 是否可修改: |
12 | get | tinyint | 3 | 0 | N | N | 1 | 是否可查看: |
13 | field_add | text | 65535 | 0 | Y | N | 添加字段: | |
14 | field_set | text | 65535 | 0 | Y | N | 修改字段: | |
15 | field_get | text | 65535 | 0 | Y | N | 查询字段: | |
16 | table_nav_name | varchar | 500 | 0 | Y | N | 跨表导航名称: | |
17 | table_nav | varchar | 500 | 0 | Y | N | 跨表导航: | |
18 | option | text | 65535 | 0 | Y | N | 配置: | |
19 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
20 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | collect_id | int | 10 | 0 | N | Y | 收藏ID: | |
2 | user_id | int | 10 | 0 | N | N | 0 | 收藏人ID: |
3 | source_table | varchar | 255 | 0 | Y | N | 来源表: | |
4 | source_field | varchar | 255 | 0 | Y | N | 来源字段: | |
5 | source_id | int | 10 | 0 | N | N | 0 | 来源ID: |
6 | title | varchar | 255 | 0 | Y | N | 标题: | |
7 | img | varchar | 255 | 0 | Y | N | 封面: | |
8 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
9 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
表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 | food_recommendations_id | int | 10 | 0 | N | Y | 美食推荐ID | |
2 | food_name | varchar | 64 | 0 | Y | N | 美食名称 | |
3 | food_types | varchar | 64 | 0 | Y | N | 美食类型 | |
4 | food_pictures | varchar | 255 | 0 | Y | N | 美食图片 | |
5 | food_prices | int | 10 | 0 | Y | N | 0 | 美食价格 |
6 | food_recommendations | varchar | 64 | 0 | Y | N | 美食推荐 | |
7 | food_introduction | text | 65535 | 0 | Y | N | 美食介绍 | |
8 | hits | int | 10 | 0 | N | N | 0 | 点击数 |
9 | praise_len | int | 10 | 0 | N | N | 0 | 点赞数 |
10 | recommend | int | 10 | 0 | N | N | 0 | 智能推荐 |
11 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
12 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | food_types_id | int | 10 | 0 | N | Y | 美食类型ID | |
2 | food_types | 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 | hits_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: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | hotel_recommendations_id | int | 10 | 0 | N | Y | 酒店推荐ID | |
2 | hotel_name | varchar | 64 | 0 | Y | N | 酒店名称 | |
3 | hotel_type | varchar | 64 | 0 | Y | N | 酒店类型 | |
4 | hotel_pictures | varchar | 255 | 0 | Y | N | 酒店图片 | |
5 | hotel_phone_number | varchar | 64 | 0 | Y | N | 酒店电话 | |
6 | hotel_prices | int | 10 | 0 | Y | N | 0 | 酒店价格 |
7 | hotel_address | text | 65535 | 0 | Y | N | 酒店地址 | |
8 | hotel_details | text | 65535 | 0 | Y | N | 酒店详情 | |
9 | hits | int | 10 | 0 | N | N | 0 | 点击数 |
10 | praise_len | int | 10 | 0 | N | N | 0 | 点赞数 |
11 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
12 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | hotel_type_id | int | 10 | 0 | N | Y | 酒店类型ID | |
2 | hotel_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 | message_id | int | 10 | 0 | N | Y | 留言板ID: | |
2 | user_id | int | 10 | 0 | N | N | 0 | 用户ID: |
3 | title | varchar | 64 | 0 | Y | N | 标题: | |
4 | content | longtext | 2147483647 | 0 | N | N | 内容: | |
5 | nickname | varchar | 32 | 0 | N | N | 昵称: | |
6 | avatar | varchar | 255 | 0 | Y | N | 头像: | |
7 | | varchar | 125 | 0 | Y | N | 留言者邮箱 | |
8 | phone | varchar | 11 | 0 | Y | N | 留言者手机号码 | |
9 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
10 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
11 | reply | longtext | 2147483647 | 0 | Y | N | 回复 | |
12 | reply_state | tinyint | 4 | 0 | Y | N | 0 | 回复状态 |
表notice (公告)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 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 | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | types_of_attractions_id | int | 10 | 0 | N | Y | 景点类型ID | |
2 | types_of_attractions | 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 | 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 | 更新时间: |
3.4本章小结
整个基于微信小程序的湛江特色推荐系统系统的需求分析主要对系统总体架构以及功能模块的设计,通过建立E-R模型和数据库逻辑系统设计完成了数据库系统设计。
- 4 章 关键模块的设计与实现
4.1.1注册界面
游客可以查看系统信息,也有注册成为用户的权限。注册界面展示如下图4-1所示。
图4-1 注册界面图
注册代码如下:
/**
* 注册
* @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.2登录界面
用户在登录界面输入账号+密码,完成验证,点击“登录”按钮,系统在用户数据库表中会对用户的账号进行匹配,账号+密码正确的话,就会登录到系统中各个用户的主管理界面,否则提示对应的信息,返回到登录的界面,其主界面展示如下图4-2所示。
图4-2登录界面图
登录代码如下:
/**
* 登录
* @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<>();
4.1.3首页界面
用户进入首页界面可根据导航进行使用系统其他功能,其主界面展示如下图4-3所示。
图4-3首页界面图
4.1.4“个人中心”首页界面
用户点击右上角“我的账户”进入个人中心个人账户首页,基本信息可修改自己的头像、名称和密码。界面如下图4-4所示。
图4-4“个人中心”首页界面图
4.1.5湛江文化界面
用户点击“湛江文化”进入查看更多湛江文化景点信息,同时可点赞、收藏和评论。界面如下图4-5所示。
图4-5湛江文化界面图
4.1.6美食推荐界面
用户点击“美食推荐”进入查看更多湛江美食详情信息,同时可点赞、收藏和评论。界面如下图4-6所示。
图4-6美食推荐界面图
4.2.1管理员首页界面
管理员进入首页界面可以通过各个功能需求进行管理。界面如下图4-7所示。
图4-7管理员首页界面图
关键代码如下:
Map<String, String> query = new HashMap<>();
String o_password = data.get("o_password");
query.put("user_id" ,String.valueOf(userId));
query.put("password" ,service.encryption(o_password));
int count = service.selectBaseCount(service.count(query, service.readConfig(request)));
if(count > 0){
4.2.2景点信息管理界面
管理员可以通过景点信息列表进行添加、查询、重置、删除操作。界面如下图4-8所示。
图4-8景点信息管理界面图
4.2.3酒店推荐管理界面
管理员可以通过酒店推荐信息列表进行添加、查询、重置、删除操作。界面如下图4-9所示。
图4-9酒店推荐管理界面图
4.2.4系统管理界面
管理员可以通过轮播管理功能来管理网站首页的轮播图片,包括添加、编辑、删除轮播图片以及设置图片的链接和显示顺序等操作。界面如下图4-10所示。
图4-10 系统管理界面图
到此,系统的开发基本完成,接下来我们对系统的实验与结果进行分析,确保系统能够正常运行,进而投入使用,对系统的实验与结果分析的检测方法就是对系统的测试,测试是系统完成的最后一步,没有测试过的系统是不能进行投入使用的,否则一旦发生bug就会造成损失,下面我们从测试的方法以及测试的用例两部分进行分析,最后给出系统的测试结果。
系统的测试方面有两种,一种是黑盒测试,另一种则为白盒测试,黑盒测试通俗来说就是功能方面的测试,我们也称之为需求测试,在黑盒测试的过程中,我们是不知道其开发原理的,只是作为一名使用者对系统进行测试,我们主要是凭借之前的测试经验,取一些临界值,然后通过测试用例来对其进行测试,这种测试方法是最快的查找问题方法,其次我们可以找一些具有代表性的数据,对系统进行用例测试,在黑盒测试的过程中常用的测试工具是winrunner和AutoRunner;白盒测试我们称之为结果测试,也就是逻辑驱动测试,在白盒测试的过程中,我们主要是根据系统开发的原理进行测试的,主要是以开发者的身份去测试这个代码是不是完成了其具体的功能,实现的具体路径对不对,当然这种测试方法是费时费力的,因为每个功能,他的运行路径不止一条,通过对程序当中运行的路径进行测试,检测开发的代码是不是存在bug,有没有实现预期,在白盒测试的过程中常用的测试工具为Jcontract、C++ Test以及CodeWizard等。
登录模块的功能测试:
表5.1 登录模块功能测试表
测试名称 | 测试功能 | 操作过程 | 预期结果 | 测试结果 |
登录模块测试 | 登录成功的情况 | 使用者可以通过浏览器进入到湛江特色推荐系统登录界面,输入用户名:admin和密码admin,完成滑动拼图验证后,点击“登录”按钮。 | 成功登录到管理员管理的界面 | 正确 |
登录模块测试 | 登录失败的情况 | 使用者可以通过浏览器进入到湛江特色推荐系统登录界面,输入用户名:admin和密码111,完成滑动拼图验证后,点击“登录”按钮。 | 系统提示“用户名和密码不匹配” | 正确 |
用户信息添加功能测试:
表5.2 用户信息添加功能测试表
测试名称 | 测试功能 | 操作过程 | 预期结果 | 测试结果 |
用户信息添加模块测试 | 用户信息添加成功的情况 | 管理员在“系统用户”菜单中点击“用户信息”会显示出所有的用户信息,点击“添加”按钮,输入账号、密码、昵称、手机号码、邮箱等,输入正确的信息后,点击“提交”按钮。 | 提示添加成功 | 正确 |
用户信息添加模块测试 | 用户信息添加失败的情况 | 管理员在“系统用户”菜单中点击“用户信息”会显示出所有的用户信息,点击“添加”按钮,不输入账号,其他信息正常填写后,点击“提交”按钮。 | 提示“添加失败,账号不能为空” | 正确 |
查询湛江文化信息功能模块测试:
表5.3 查询湛江文化信息功能测试表
测试名称 | 测试功能 | 操作过程 | 预期结果 | 测试结果 |
查询湛江文化信息功能测试 | 查询成功的情况 | 用户在菜单栏中点击“湛江文化信息”,然后会出现系统中所有的湛江文化信息 | 查询成功 | 正确 |
景点信息添加功能模块测试:
表5.4 添加景点信息功能测试表
测试名称 | 测试功能 | 操作过程 | 预期结果 | 测试结果 |
景点信息添加模块测试 | 景点信息添加成功的情况 | 点击 “景点信息”这个菜单,输入景点信息即可提交信息。 | 提示提交成功 | 正确 |
景点信息添加模块测试 | 景点信息添加失败的情况 | 提交景点信息信息时,不输入景点门票,其他信息正常填写后,点击“提交”按钮。 | 提示“添加失败,信息不能为空” | 正确 |
在本章节对湛江特色推荐系统进行了黑白盒测试,并对系统中的部分功能进行了用例分析,能够发现系统还是比较稳定的,系统的所有功能基本可以实现,能够满足管理员和用户对旅游资讯、景点信息添加、用户信息添加等需求。通过测试可以看出在系统的运行过程中,其功能完整,对于输入的错误信息,能够把错误信息提示出来,方便用户操作的时候发现自己输入的信息哪里有错误,进而进行改正,而且系统界面都设有导航栏,操作非常便捷,不需要对使用者进行任何培训,对于企业来说是一个很有价值的系统。
通过本次对基于Spring Boot框架的湛江特色推荐系统的设计与实现的探讨,我们对于如何构建一个旨在为用户提供个性化湛江旅游推荐服务的系统有了更深入的了解。在系统功能需求分析中,我们详细列举了普通用户模块和管理员用户模块的功能需求,确保系统能够满足用户浏览、管理和推荐的需求。通过对技术可行性的分析,我们确认了Spring Boot框架在实现特色推荐系统方面的优势和可行性。
湛江特色推荐系统的设计与实现将为当地旅游业发展带来新的机遇和活力。对于普通用户来说,他们将能够方便地浏览和搜索湛江的特色景点、美食和酒店信息,获得个性化的推荐服务,提升旅游体验。而对于管理员来说,他们将能够高效地管理系统的各项信息和用户反馈,保障系统运行的顺畅和信息的准确性。
综上所述,基于Spring Boot框架的湛江特色推荐系统的设计与实现将有助于提升湛江旅游服务的智能化水平,推动当地旅游产业的发展,并为用户和管理员带来更便捷和丰富的服务体验。相信在各方共同努力下,湛江特色推荐系统必将成为当地旅游业发展的重要助力,为湛江市的旅游业带来更多的机遇和活力。
参考文献
[1]赵新宁,韩松妍.乡村文旅不是文化与旅游简单叠加[N].农民日报,2024-03-28(008).
[2]林革.中国式现代化视域下广西旅游业高质量发展研究[J/OL].改革与战略,1-11[2024-03-29].http://kns.cnki.net/kcms/detail/45.1006.C.20240325.1242.002.html.
[3]任新玉.吉林省湛江文化助推乡村振兴高质量发展研究[J].长春大学学报,2024,34(03):1-6.
[4]任新玉.吉林省湛江文化助推乡村振兴高质量发展研究[J/OL].长春大学学报,2024,(03):1-6[2024-03-29].http://kns.cnki.net/kcms/detail/22.1283.G4.20240325.1708.002.html.
[5]王超,崔华清.乡村休闲旅游政策的量化评价与发展展望[J/OL].旅游学刊,1-16[2024-03-29].https://doi.org/10.19765/j.cnki.1002-5006.2024.00.017.
[6]孔垂炼.临沧湛江文化渐入佳境[N].云南经济日报,2024-03-21(A02).
[7]厉承烨,杨芳,李易.乡村休闲旅游发展路径——以江西上饶葛仙村夜间旅游为例[J].南方农机,2024,55(06):114-117.
[8]王珂.激发湛江文化更大动能[N].人民日报,2024-03-20(019).DOI:10.28655/n.cnki.nrmrb.2024.002797.
[9]何静,李珂,贾丹阳.湛江文化营销策略研究——以河南省洛阳市栾川县为例[J].农村.农业.农民(B版),2024,(03):21-23.
[10]赵萍.彝族地区湛江文化合作社数字化平台建设探析[J].现代农机,2024,(02):32-34.
[11]李丽,田志奇.海南乡村亲子旅游高质量发展路径探析[J].商业经济,2024,(04):64-66+92.DOI:10.19905/j.cnki.syjj1982.2024.04.020.
[12]吴贤贤.海南湛江文化建设数字化转型发展调查研究——以澄迈罗驿古村为例[J].现代商贸工业,2024,45(08):26-29.DOI:10.19311/j.cnki.1672-3198.2024.08.009.
[13]张阳阳,杨丞娟,王闰星.基于PEST-SWOT模型的湛江文化发展分析——以浙江白水洋镇为例[J].现代化农业,2024,(03):39-43.
[14]王仁通,梁龙.基于IPA方法的湛江文化发展对策研究[J].安徽农学通报,2024,30(05):135-139.DOI:10.16377/j.cnki.issn1007-7731.2024.05.012.
[15]李雪茹,穆红梅,文莹莹.国内外湛江文化发展模式对我国乡村振兴的启示[J].农业与技术,2024,44(05):138-142.DOI:10.19754/j.nyyjs.20240315032.
[16]Król K ,Zdonek D .Digital artefacts of rural tourism: the case study of Poland[J].Global Knowledge Memory and Communication,2024,73(3):258-273.
[17]Harsich M G ,Forné F F ,Fernandes C , et al.Artisanal food production in rural Argentina: Finding solace in cheese tourism?[J].International Journal of Gastronomy and Food Science,2024,35100888-.
[18]Yanan L ,Ismail A M ,Aminuddin A .How has rural tourism influenced the sustainable development of traditional villages? A systematic literature review[J].Heliyon,2024,10(4):e25627-.
[19]陶琳,张宜弛.微信公众号传播对地方旅游业推介的价值探究——以张掖市为例[J].新闻研究导刊,2024,15(03):71-73.
[20]赵寒影.“互联网+”背景下河南省旅游业发展策略分析[J].北方经贸,2024,(02):153-156.
致 谢
在完成基于springboot湛江特色推荐系统过程中,我要衷心感谢所有参与其中的导师和团队成员给予的支持和帮助。他们的贡献使得这个项目能够顺利完成。
衷心感谢我的导师对我的悉心指导和鼓励。您的专业知识和经验对我产生了深远的影响,使我能够更好地理解和研究教材管理系统。您的建议和指导让我不断进步,对我而言是一笔宝贵的财富。
还要感谢为本项目提供数据和资源的相关机构和个人。他们的合作和帮助使我能够收集到可靠的信息和资料,并进行准确的分析和研究。没有他们的支持,我将无法展开深入的探索和论证。
最后,我要感谢匿名评审专家和阅读者们。感谢您们抽出宝贵的时间对我的论文进行评审和提供宝贵的意见和建议。您们的专业知识和批判性思维使我能够不断完善和改进我的研究成果。
致以最诚挚的谢意!
免费领取项目源码,请关注❥点赞收藏并私信博主,谢谢~