目 录
摘要
1 绪论
1.1 研究背景
1.2 研究意义
1.3研究方案
1.4 开发技术
1.4.1 B/S架构
1.4.2 Spring Boot框架
1.4.3 Java语言
1.4.4 MySQL数据库
1.5论文布局与章节安排
2体系分析
2.1 可行性分析
2.2 体系流程分析
2.2.1 用户登录流程
2.2.2数据删除流程
2.3 体系功能分析
2.4 体系用例分析
2.5本章小结
3 体系总体设计
3.1总体设计原则
3.2 体系架构设计
3.3体系功能模块设计
3.3.1团体功能模块设计
3.3.2体系用户模块设计
3.3.3新闻信息管理模块设计
3.4 数据库设计
3.4.1 数据库概念布局设计
3.4.2 数据库逻辑布局设计
3.4本章小结
4 体系详细设计与实现
4.1注册用户功能模块
4.1.1用户注册界面
4.1.2用户登录界面
4.1.3首页界面
4.1.4 网站公告界面
4.1.5 留言反馈界面
4.1.6 新闻信息界面
4.1.7个人中心界面
4.2管理员功能模块
4.2.1体系用户界面
4.2.2新闻分类管理界面
4.2.3新闻信息管理界面
4.2.4体系管理界面
4.2.5留言管理界面
4.2.6网站公告管理界面
5体系测试
5.1测试目的
5.2 测试用例
5.3 测试效果
6 结论
参考文献
致 谢
摘要
随着互联网技术的飞速发展和新闻媒体的数字化,用户每天面临的信息量呈爆炸式增长。如何从海量信息中快速、正确地找到用户感爱好的内容,成为了一个亟待办理的问题。为此,本文提出了一种基于Spring Boot架构的新闻推荐体系。Spring Boot框架提供了主动设置、依赖管理、内嵌服务器等功能,可以帮助我们快速构建Java应用。在新闻推荐体系中,Spring Boot将用于搭建后端服务,提供API接口供前端页面调用。本体系采用协同过滤的算法,根据用户的爱好和举动,向用户推荐干系的新闻,进步用户的信息获取服从。
本文起首阐述了体系的研究背景、意义和开发技术;然后对体系举行了可行性、功能性中分析;接着详细介绍了体系的设计原理和实现细节,包括体系架构、主要功能模块和数据库设计等;末了对体系举行了摆设和测试。通过本体系的的实施,可以大概帮助用户更加高效地获取自己关心的新闻资讯,节流了用户在海量信息中搜刮浏览的时间。
关键词:新闻推荐体系;调和过滤;Spring Boot
Abstract
With the rapid development of Internet technology and the digitalization of news media, the amount of information users face every day is exploding. How to quickly and accurately find content that users are interested in from massive amounts of information has become an urgent problem to be solved. Therefore, this article proposes a news recommendation system based on the Spring Boot architecture. The Spring Boot framework provides features such as automatic configuration, dependency management, and embedded servers, which can help us quickly build Java applications. In the news recommendation system, Spring Boot will be used to build backend services and provide API interfaces for front-end pages to call. This system adopts a collaborative filtering algorithm to recommend relevant news to users based on their interests and behaviors, improving their information acquisition efficiency.
This article first elaborates on the research background, significance, and development technology of the system; Then, feasibility and functionality analyses were conducted on the system; Then, the design principles and implementation details of the system were introduced in detail, including system architecture, main functional modules, and database design; Finally, the system was deployed and tested. Through the implementation of this system, it can help users more efficiently obtain news and information they are concerned about, saving them time searching and browsing through massive amounts of information.
Keywords: News recommendation system; Coordinated filtering; Spring Boot
1 绪论
1.1 研究背景
随着互联网的遍及和技术的不断进步,信息产生和传播的速率达到了前所未有的高度。用户在面临海量信息时,很难快速找到自己感爱好的内容。当代社会的快节奏和个性化趋势使得用户对新闻的需求也变得更加多样化和个性化。他们盼望获得与自己爱好、职业、地域等干系的新闻内容,而非传统的、无差异的新闻推送。因此,新闻推荐体系成为了办理这一问题的有效本领。
随着大数据、人工智能等技术的不断发展,为新闻推荐体系提供了强大的技术支持。这些技术可以帮助体系更好地分析用户举动、爱好偏好等,从而实现更正确的新闻推荐。协同过滤算法是一种成熟的个性化推荐技术,它通过分析用户的汗青举动数据,如浏览、点赞、批评等,来预测用户的爱好偏好,从而为用户提供更加精准的新闻推荐。这种算法可以大概有效地办理信息过载的问题,帮助用户从海量信息中筛选出感爱好的内容,提升阅读体验。此外,基于协同过滤算法的新闻推荐体系另有助于加强新闻媒体的传播效果。通过分析用户的举动数据,体系可以大概了解用户的爱好和需求,从而为用户推荐更加符合其需求的新闻内容。这不但可以大概进步新闻的点击率和阅读率,还可以大概加强用户对新闻媒体的黏性和忠诚度。
此外,Spring Boot是一个开源的Java框架,它提供了丰富的功能和工具,使得开发人员可以大概更快速、更简朴地构建Web应用步伐。因此,采用Spring Boot框架开发新闻推荐体系,可以大大进步开发服从,缩短开发周期,同时也保证了体系的稳定性和可靠性。
1.2 研究意义
随着互联网的快速发展,新闻信息的传播速率和数量也在不断增加。用户在浏览新闻时,面临着信息过载的问题,无法有效地获取自己感爱好的新闻。因此研究基于Spring Boot架构的新闻推荐体系具有紧张的意义,主要表现在以下几个方面:
起首,可以进步用户体验。新闻推荐体系可以大概根据用户的爱好、偏好和举动,为用户推荐更加精准、个性化的新闻内容。如许,用户可以更快地找到自己感爱好的新闻,减少信息搜刮的时间和成本,进步用户的满意度和体验。
其次,可以优化内容分发。新闻推荐体系通过对大量新闻内容举行智能分析和处理处罚,可以大概根据用户的爱好和需求,将新闻内容举行精准推送,从而实现更加高效的内容分发。这有助于进步新闻媒体的传播效果和影响力,同时也可以大概更好地满意用户的需求。
末了,有助于促进媒体转型:随着数字化、智能化的快速发展,传统新闻媒面子临着转型和发展的寻衅。新闻推荐体系作为一种新兴的技术本领,有助于推动传统新闻媒体向数字化、智能化方向转型,进步媒体的竞争力和可连续发展能力。
1.3研究方案
- 需求分析:通过在图书馆大概网上查找与体系干系的资料,对体系举行需求分析以了解体系的根本特征和想要实现目标,确定体系功能需求。
- 体系设计:根据需求分析的效果,设计出符合用户需求的新闻推荐体系。这包括体系的架构设计、功能模块设计、数据库设计等。
- 功能实现:在体系设计的基础上,使用Spring Boot等开发工具,实现体系的各项功能。主要包括用户管理、新闻信息管理、留言管理等功能。
- 完成体系界面的设计:从用户需求出发,设计一个简洁友好且易于操作的体系界面,以提升用户体验。
- 完成体系的实现:完成各个功能模块的详细编程实现,将设计效果转化为计算机可运行的步伐。
- 完成体系的测试与美满:结合实际对体系的运行举行测试分析,包括功能测试、性能测试、安全性测试等,如果发现体系有存在的问题将对问题举行分析并办理问题,确保体系的稳定性和可靠性。
1.4 开发技术
本体系采用B/S模式,采用基于Java的Spring Boot框架举行开发,同时集成MyBatis、Redis等干系技术,使用MySQL数据库来存储和管理体系数据。
1.4.1 B/S架构
B/S架构(浏览器/服务器)是当前应用最为广泛的一种架构,可以大概使体系的开发变得容易、易操作、易于维护。当你在你的电脑上安装一个数据库和几个非常常见的浏览器时,你就可以使用这个布局。B/S布局可以直接用于 B/S体系,并且 B/S架构可以在实际应用中大大降低了体系的运行维护。在 B/S平台上,各数据库彼此独立,具有很高的安全性。由于 B/S架构可以清晰地观察到体系所处理处罚的业务,使管理者可以实时做出决定,从而避免了企业的亏损。B/S架构的本质特征是集中式管理,用户通过体系产生的数据,将其存入数据库,便于以后的应用,从而达到了各种需要。
B/S模子由一个浏览器、一个网络服务器、一个数据库服务器三个层级构成。数据管理采用了当前大部分现有B/S体系的表现层、应用层和数据层,Web浏览器是为了满意用户的要求而设计的,在数据处理处罚和逻辑过程中使用的中心应用层,从而形成分布式的运行模式。B/S体系布局的逻辑是:在前端完成的处理处罚,将主要的业务逻辑交给后台,而前端只负责少量的请求、渲染等。由于因特网技术的迅速发展,B/S体系布局使得任何时间、任何地点都能访问到该体系。
图1-1 B/S模式三层布局图
1.4.2 Spring Boot框架
Spring Boot是一个用于创建独立的、基于Spring的应用步伐的框架。它简化了基于Java的应用步伐的开发过程,提供了一种快速构建可摆设的生产级应用步伐的方式。它的主要特点是主动设置和约定优于设置。它通过使用默认值和主动设置来减少开发人员的设置工作量,使开发过程更加简朴和高效。它还提供了一个起步依赖(Starter POM)的概念,可以一站式引入干系的依赖库和设置,以快速搭建项目。
它还具有内嵌的Web服务器,如Tomcat或Jetty,这使得应用步伐可以作为一个独立的可实行JAR文件运行。此外,它还提供了健康查抄、度量指标、安全性等方面的功能,帮助开发人员更好地管理和监控应用步伐。它采用了Spring框架的核心功能,如依赖注入、面向切面编程等,并结合了其他开源项目,如Spring Data、Spring Security等,提供了丰富的功能和扩展性。
综上所述,Spring Boot是一个简化了Spring应用步伐开发的框架,它提供了主动设置、约定优于设置、起步依赖等特性,使得开发人员可以更加便捷地构建可摆设的应用步伐。它的出现极大地简化了Java开发过程,进步了开发服从和项目的可维护性。
1.4.3 Java语言
早在上个世纪90年代,Java就由詹姆斯·高斯林举行开发,自诞生之日起,Java就一直深深的受到了步伐开发者的广泛喜好,它作为计算机主要的编程语言,一直到今。Java语言是真的是一种纯面向对象的计算机语言,在Java的世界中,所有的方法、数据类型、符号等都是以类的方式存在的,最顶层的就是Object,所有的类都是对object的继承。继承是Java中的核心思想,与C语言不同的是,子类只有一个父类,如许的好处就是操作更加的简便,让人更容易理解,在代码的誊写上也会容易较多。Java另外一个特性就是多态性,调用父类接口的方法可以实现子类的实现,如许的好处就是很好的对实现方法举行了隐蔽(封装),而且又可以大概把API举行公开,一石二鸟。接口思想很好的诠释了想象对象的思想,让面向对象编程渐渐转向面向接口编程。现在,随着编程思想的继续发展,Java也加入了一些函数式编程的思想,如许的好处就是让编程代码更加的简洁与方便。本管理体系采用Java编程语言举行后台的开发,一是鉴于标准化制定以后,Java语言常用于大型贸易应用步伐后台体系中,生态稳定;二是也盼望通过本体系的开发进步自己编写Java代码的能力。
1.4.4 MySQL数据库
MySQL 经过多次的更新,功能层面已经非常的丰富和美满了,从MySQL4版本到5版本举行了比较大的更新,在贸易的实际使用中取得了很好的实际应用效果。最新版本的MySQL支持对信息的压缩,同时还能举行加密能更好的满意对信息安全性的需求。同时经过体系的多次更新,数据库自身的镜像功能也得到了很大的加强,运行的流畅度和易用性方面有了不小的进步,驱动的使用和创建也更加的高效快捷。最大的变更还是举行了空间信息的表现优化,能更加方便的在应用舆图上举行坐标的标注和运算。强大的备份功能也保证了用户使用的过程会更加安心,同时支持的Office特性还支持用户的自行安装和使用。在信息的表现情势上也举行了不小的更新,增加了两个非常使用的表现区,一个是信息区,对表格和笔墨举行了分类处理处罚,界面的表现更加清爽和详细。第二是仪表的信息控件,能在仪表信息区举行信息的表现,同时还能举行多个信息的比对,为用户的实际使用带来了很大的便捷。
1.5论文布局与章节安排
论文将分层次举行编排,撤除论文摘要致谢文献参考部分,正文部分主要布局如下:
第一章:绪论,此章节对所设计和实现的体系的背景以及开发技术举行详细的叙述以及说明,同时举行了论文团体框架的布局的简要介绍。
第二章:体系分析,此章节所做的主要的工作是对体系举行了技术、经济等方面的可行性的分析;对体系实验了总体功能的需求、用例分析。
第三章:体系总体设计,主要是对体系的功能布局举行设计,并对体系数据库的概念布局以及物理布局的设计举行了分析。
第四章:体系详细设计与实现,根据体系功能的分别,分别的对体系所需要实现的用户功能和管理员功能举行了分析和说明。
第五章:体系测试,主要介绍了体系测试目的和对体系的部分功能界面举行测试并对测试效果作出总结。
第六章:结论,主要对体系的开发设计工作举行总结。
2体系分析
体系分析是开发一个项目的先决条件,通过体系分析可以很好的了解体系的主体用户的根本需讨环境,同时这也是项目的开发的缘故原由。进而对体系开发举行可行性分析,通常包括技术可行性、经济可行性等,可行性分析同时也是从项目团体角度举行的分析。然后就是对项目的详细需求举行分析,分析的本领一般都是通过用户的用例图来实现。下面是详细的介绍。
2.1 可行性分析
(1)技术可行性
Spring Boot作为一种成熟的Java框架,具有丰富的功能和广泛的社区支持,使得开发过程更为简便和高效。同时,Spring Boot也提供了精良的扩展性和可维护性,可以大概满意新闻推荐体系的功能需求,并且使得体系在未来可以大概方便地举行功能扩展和升级。因此,从技术层面分析是可行的。
(2)经济可行性
Spring Boot的主动设置功能可以根据应用步伐的依赖和环境来举行主动设置,减少了大量的手动设置工作,可以降低开发成本;另外,Spring Boot的代码质量和可维护性较高,可以降低后期维护成本。因此,从经济角度分析是可行的。
(3)社会可行性
随着互联网技术的快速发展,用户对新闻的需求也日益增长。新闻推荐体系可以根据用户的爱好和偏好,提供个性化的新闻推荐服务,满意用户的需求。因此,从社会角度分析是可行的。
2.2 体系流程分析
体系流程是用一些特定的符合和线条来举行演示用户在使用体系时的过程,在举行体系分析的时间,业务流程可以帮助开发人员更好的理解业务,发现错误,美满体系。
2.2.1 用户登录流程
用户通过登录才能访问体系及权限以内的功能,对此将实现各种应用及管理等功能,用户登录流程图如下图2-1所示。
图2-1 登录流程图
2.2.2数据删除流程
如果体系内里存在一些没有用的数据,干系的管理人员还可以对这些数据举行删除,数据删除时流程图如下图2-3所示。
图2-2 数据删除流程图
2.3 体系功能分析
按照基于Spring Boot架构的新闻推荐体系的角色,主要包括注册用户和管理员这两大功能模块,各模块功能如下。
- 注册登录:新用户可以通过注册成为体系用户,注册后可以用账号密码登录体系。
- 首页:用户可以查看首页展示的导航栏、轮播图,网站公告、新闻资讯、新闻信息推荐等信息。
- 网站公告:用户可以查看体系发布的网站公告、关于我们、联系方式、网站介绍等信息。
- 留言反馈:用户可以发布留言内容,可以查看留言反馈列表中某个用户发布的留言信息。
- 新闻信息:用户可以查看新闻信息列表中某个新闻信息的详情并可以点赞、收藏和批评。
- 我的:用户点击我的头像的下拉菜单“我的账户”进入页面可以修改个人资料和登录密码;点击“个人中心”进入页面可以查看和管理个人首页、留言反馈和收藏信息;点击“退出”即可退出体系登录。
- 登录:管理员的账号和密码是事先在数据库中设定好的,管理员可以通过在后台输入正确的账号和密码举行登录。
- 后台首页:管理员可以查看后台首页展示的干系信息。
- 体系用户:管理员可以查看体系用户(管理员、注册用户)列表中某个用户的详情,可以对体系用户信息举行增编削查操作。
- 新闻分类管理:管理员可以查看新闻分类列表中某个分类的详情,可以对新闻分类信息举行增编削查操作。
- 新闻信息管理:管理员可以查看新闻信息列表中某个新闻的详情和批评,可以对新闻信息举行增编削查操作。
- 体系管理:管理员在“体系管理”这一菜单下对轮播图举行管控,可以对轮播图信息举行增编削查操作。
- 留言管理:管理员可以查看留言反馈列表中某个用户提交的留言反馈信息的详情并可以举行复兴操作;可以对通列表信息举行查询、重置和删除操作。
- 网站公告管理:网站公告管理界面是管理员用来管理体系中的通知公告的界面,管理员可以对网站公告信息举行增编削查操作。
- 我的:管理员可以修改个人信息和登录密码;可以浏览网站首页;点击“退出”即可退出体系的登录。
2.4 体系用例分析
通过2.3功能的分析,得出了本体系的用例图:
注册用户用例图如下图2-3所示。
图2-3注册用户用例图
管理员用例图如下图2-4所示。
图2-4 管理员用例图
2.5本章小结
本章主要通过对基于Spring Boot架构的新闻推荐体系的可行性分析、流程分析、功能需求分析、体系用例分析,确定整个体系要实现的功能。同时也为体系的代码实现和测试提供了标准。
3 体系总体设计
本章主要讨论的内容包括基于Spring Boot架构的新闻推荐体系的总体设计原则、架构设计、功能模块设计和数据库设计。
3.1总体设计原则
一个体系要在开发和维护的过程中方便使用,必须采取一定的设计原则,其主要设计原则有:
简朴性:体系功能简朴易懂,只需要把握根本的计算机操作能力即可使用。
针对性:针对特定的用户,没有多余的其他功能,使用户可以专心使用。
实用性:可以大概满意用户查看新闻信息、用户信息等方面的需求。
先进性:本体系的代码采用读取数据的方式,方便后续开发、拓展。
3.2 体系架构设计
本体系从架构上分为三层:表现层(UI)、业务逻辑层(BLL)以及数据层(DL)。
图3-1体系架构设计图
表现层(UI):又称UI层,主要完成本体系的UI交互功能,一个精良的UI可以打打进步用户的用户体验,加强用户使用本体系时的舒服度。UI的界面设计也要顺应不同版本的体系以及不同尺寸的分辨率,以做到精良的兼容性。UI交互功能要求公道,用户举行交互操作时必须要得到与之符合的交互效果,这就要求表现层要与业务逻辑层举行精良的对接。
业务逻辑层(BLL):主要完成本体系的数据处理处罚功能。用户从表现层传输过来的数据经过业务逻辑层举行处理处罚交付给数据层,体系从数据层读取的数据经过业务逻辑层举行处理处罚交付给表现层。
数据层(DL):由于本体系的数据是放在服务端的MySQL数据库中,因此本属于服务层的部分可以直接整合在业务逻辑层中,所以数据层中只有数据库,其主要完成本体系的数据存储和管理功能。
3.3体系功能模块设计
3.3.1团体功能模块设计
在上一章节中主要对体系的功能性需求和非功能性需求举行分析,并且根据需求分析了体系中的用例。那么接下来就要开始对本体系的主要功能和数据库开始举行设计。基于根据前面章节的需求分析得出,其总体设计模块图如图3-1所示。
图3-2 体系功能模块图
3.3.2体系用户模块设计
用户模块是体系中一个紧张的功能模块,它涉及用户的注册、登录、个人信息管理等操作。在用户模块设计中,我们将定义用户数据的布局和属性,包括用户名、密码、邮箱等。同时,还需要实现用户注册、登录、修改密码等功能,并对用户输入举行验证和处理处罚。用户模块的布局图如下图3-3所示:
图3-3体系用户模块布局图
3.3.3新闻信息管理模块设计
新闻信息管理模块是本体系中的紧张功能之一。该模块的设计旨在提供对新闻信息的发布、编辑、删除和查看等管理功能,以便实时、正确地向体系用户发布干系的新闻信息。其模块功能布局图如下图3-4所示:
图3-4新闻信息管理模块布局图
3.4 数据库设计
数据库设计一般包括需求分析、概念模子设计、数据库表创建三大过程,其中需求分析前面章节已经阐述,概念模子设计有概念模子和逻辑布局设计两部分。
3.4.1 数据库概念布局设计
下面是整个基于Spring Boot架构的新闻推荐体系中主要的数据库表总E-R实体关系图。
图3-5 体系总E-R关系图
3.4.2 数据库逻辑布局设计
通过上一末节中基于Spring Boot架构的新闻推荐体系中总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
| 用户编号:
| 表auth (用户权限管理)
编号
| 名称
| 数据类型
| 长度
| 小数位
| 允许空值
| 主键
| 默认值
| 说明
| 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
| 更新时间:
| 表collect (收藏)
编号
| 名称
| 数据类型
| 长度
| 小数位
| 允许空值
| 主键
| 默认值
| 说明
| 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:
| 表hits (用户点击)
编号
| 名称
| 数据类型
| 长度
| 小数位
| 允许空值
| 主键
| 默认值
| 说明
| 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:
| 表message (留言板)
编号
| 名称
| 数据类型
| 长度
| 小数位
| 允许空值
| 主键
| 默认值
| 说明
| 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
| email
| 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
| 复兴状态
| 表news_classification (新闻分类)
编号
| 名称
| 数据类型
| 长度
| 小数位
| 允许空值
| 主键
| 默认值
| 说明
| 1
| news_classification_id
| int
| 10
| 0
| N
| Y
|
| 新闻分类ID
| 2
| news_classification
| 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
| 更新时间
| 表news_information (新闻信息)
编号
| 名称
| 数据类型
| 长度
| 小数位
| 允许空值
| 主键
| 默认值
| 说明
| 1
| news_information_id
| int
| 10
| 0
| N
| Y
|
| 新闻信息ID
| 2
| news_headlines
| varchar
| 64
| 0
| Y
| N
|
| 新闻标题
| 3
| news_cover
| varchar
| 255
| 0
| Y
| N
|
| 新闻封面
| 4
| release_time
| datetime
| 19
| 0
| Y
| N
|
| 发布时间
| 5
| news_sources
| varchar
| 64
| 0
| Y
| N
|
| 新闻泉源
| 6
| news_author
| varchar
| 64
| 0
| Y
| N
|
| 新闻作者
| 7
| responsible_editor
| varchar
| 64
| 0
| Y
| N
|
| 责任编辑
| 8
| news_tags
| varchar
| 64
| 0
| Y
| N
|
| 新闻标签
| 9
| news_classification
| varchar
| 64
| 0
| Y
| N
|
| 新闻分类
| 10
| news_description
| text
| 65535
| 0
| Y
| N
|
| 新闻形貌
| 11
| news_content
| longtext
| 2147483647
| 0
| Y
| N
|
| 新闻内容
| 12
| hits
| int
| 10
| 0
| N
| N
| 0
| 点击数
| 13
| praise_len
| int
| 10
| 0
| N
| N
| 0
| 点赞数
| 14
| recommend
| int
| 10
| 0
| N
| N
| 0
| 智能推荐
| 15
| create_time
| datetime
| 19
| 0
| N
| N
| CURRENT_TIMESTAMP
| 创建时间
| 16
| update_time
| timestamp
| 19
| 0
| N
| N
| CURRENT_TIMESTAMP
| 更新时间
| 表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
| 更新时间:
| 表praise (点赞)
编号
| 名称
| 数据类型
| 长度
| 小数位
| 允许空值
| 主键
| 默认值
| 说明
| 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已取消
| 表registered_users (注册用户)
编号
| 名称
| 数据类型
| 长度
| 小数位
| 允许空值
| 主键
| 默认值
| 说明
| 1
| registered_users_id
| int
| 10
| 0
| N
| Y
|
| 注册用户ID
| 2
| mobile_phone_number
| varchar
| 16
| 0
| Y
| N
|
| 手机号码
| 3
| examine_state
| varchar
| 16
| 0
| N
| N
| 已通过
| 审核状态
| 4
| user_id
| int
| 10
| 0
| N
| N
| 0
| 用户ID
| 5
| create_time
| datetime
| 19
| 0
| N
| N
| CURRENT_TIMESTAMP
| 创建时间
| 6
| update_time
| timestamp
| 19
| 0
| N
| N
| CURRENT_TIMESTAMP
| 更新时间
| 表slides (轮播图)
编号
| 名称
| 数据类型
| 长度
| 小数位
| 允许空值
| 主键
| 默认值
| 说明
| 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
| 更新时间:
| 表upload (文件上传)
编号
| 名称
| 数据类型
| 长度
| 小数位
| 允许空值
| 主键
| 默认值
| 说明
| 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
|
| 文件类型
| 表user (用户账户:用于保存用户登录信息)
编号
| 名称
| 数据类型
| 长度
| 小数位
| 允许空值
| 主键
| 默认值
| 说明
| 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
| email
| 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
| 会员折扣
| 表user_group (用户组:用于用户前端身份和鉴权)
编号
| 名称
| 数据类型
| 长度
| 小数位
| 允许空值
| 主键
| 默认值
| 说明
| 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本章小结
整个基于Spring Boot架构的新闻推荐体系的需求分析主要对体系总体架构以及功能模块的设计,通过创建E-R模子和数据库逻辑体系设计完成了数据库体系设计。
4 体系详细设计与实现
4.1注册用户功能模块
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<>();
if(username != null && "".equals(username) == false){
map.put("username", username);
resultList = service.selectBaseList(service.select(map, new HashMap<>()));
}
else if(email != null && "".equals(email) == false){
map.put("email", email);
resultList = service.selectBaseList(service.select(map, new HashMap<>()));
}
else if(phone != null && "".equals(phone) == false){
map.put("phone", phone);
resultList = service.selectBaseList(service.select(map, new HashMap<>()));
}else{
return error(30000, "账号或密码不能为空");
}
if (resultList == null || password == null) {
return error(30000, "账号或密码不能为空");
}
//判断是否有这个用户
if (resultList.size()<=0){
return error(30000,"用户不存在");
}
User byUsername = (User) resultList.get(0);
Map<String, String> groupMap = new HashMap<>();
groupMap.put("name",byUsername.getUserGroup());
List groupList = userGroupService.selectBaseList(userGroupService.select(groupMap, new HashMap<>()));
if (groupList.size()<1){
return error(30000,"用户组不存在");
}
UserGroup userGroup = (UserGroup) groupList.get(0);
//查询用户审核状态
if (!StringUtils.isEmpty(userGroup.getSourceTable())){
String res = service.selectExamineState(userGroup.getSourceTable(),byUsername.getUserId());
if (res==null){
return error(30000,"用户不存在");
}
if (!res.equals("已通过")){
return error(30000,"该用户审核未通过");
}
}
//查询用户状态
if (byUsername.getState()!=1){
return error(30000,"用户非可用状态,不能登录");
}
String md5password = service.encryption(password);
if (byUsername.getPassword().equals(md5password)) {
// 存储Token到数据库
AccessToken accessToken = new AccessToken();
accessToken.setToken(UUID.randomUUID().toString().replaceAll("-", ""));
accessToken.setUser_id(byUsername.getUserId());
Duration duration = Duration.ofSeconds(7200L);
redisTemplate.opsForValue().set(accessToken.getToken(), accessToken,duration);
// 返回用户信息
JSONObject user = JSONObject.parseObject(JSONObject.toJSONString(byUsername));
user.put("token", accessToken.getToken());
JSONObject ret = new JSONObject();
ret.put("obj",user);
return success(ret);
} else {
return error(30000, "账号或密码不正确");
}
}
4.1.3首页界面
首页界面是用户访问体系的入口页面,它展示体系的主要功能和特色。用户可以查看首页展示的导航栏、轮播图,网站公告、新闻资讯、新闻信息推荐等信息。新闻信息推荐使用调和过滤算法对新闻分类举行推荐,点击量高的排在前面。其界面展示如下图4-3所示。
图4-3 首页界面图
4.1.4 网站公告界面
用户可以查看体系发布的网站公告、关于我们、联系方式、网站介绍等信息。点击网站公告进入页面可以查看该公告的详细信息。其界面如下图4-4所示。
图4-4 通网站公告界面图
4.1.5 留言反馈界面
用户可以查看留言反馈列表中某个用户发布的留言信息,点击“留言”进入页面填写标题、留言内容后点击“提交”留言即可完成留言的发布。其界面如下图4-5所示。
图4- 留言反馈界面图
4.1.6 新闻信息界面
用户可以查看新闻信息列表中某个新闻信息的详情并可以点赞、收藏和批评;支持通过关键字搜刮、下拉搜刮方式查找新闻信息。其界面如下图4-6所示。
图4-6 新闻信息界面图
4.1.7个人中心界面
用户点击我的头像的下拉菜单“个人中心”进入页面可以查看和管理个人首页、留言反馈和收藏信息。点击“留言反馈”进入页面可以查看列表中某个留言反馈的详情,可以查询、重置和删除留言反馈信息;可以查看或删除收藏列表信息。其界面如下图4-7所示。
图4-7个人中心界面图
4.2管理员功能模块
4.2.1体系用户界面
管理员可以查看体系用户(管理员、注册用户)列表中某个用户的详情,可以对体系用户信息举行增编削查操作。其界面如下图4-8所示。
图4-8体系用户界面图
添加的代码如下:
@PostMapping("/add")
@Transactional
public Map<String, Object> add(HttpServletRequest request) throws IOException {
service.insert(service.readBody(request.getReader()));
return success(1);
}
public Map<String, Object> addMap(Map<String,Object> map){
service.insert(map);
return success(1);
}
4.2.2新闻分类管理界面
管理员可以查看新闻分类列表中某个分类的详情,可以查询、重置和删除列表信息;点击“新闻分类添加”进入页面填写新闻分类信息后点击“提交”即可完成分类信息的添加。其界面如下图4-9所示。
图4-9新闻分类管理界面图
删除的代码如下:
@RequestMapping(value = "/del")
@Transactional
public Map<String, Object> del(HttpServletRequest request) {
service.delete(service.readQuery(request), service.readConfig(request));
return success(1);
}
public void delete(Map<String,String> query,Map<String,String> config){
QueryWrapper wrapper = new QueryWrapper<E>();
toWhereWrapper(query, "0".equals(config.get(FindConfig.GROUP_BY)),wrapper);
baseMapper.delete(wrapper);
log.info("[{}] - 删除操作:{}",wrapper.getSqlSelect());
}
4.2.3新闻信息管理界面
管理员可以查看新闻信息列表中所有新闻信息的详情和批评信息,可以对列表信息举行查询、重置和删除操作;点击“新闻信息添加”进入页面填写新闻标题、发布时间、新闻泉源。新闻作者等信息并上传新闻图片后点击“提交”即可完成新闻信息的添加。其界面如下图4-10所示。
图4-10新闻信息管理界面图
4.2.4体系管理界面
管理员在“体系管理”这一菜单下对轮播图举行管控,可以对轮播图信息举行增编削查操作。其界面如下图4-11所示。
图4-11体系管理界面图
图片上传的代码如下:
@PostMapping("/upload")
public Map<String, Object> upload(@RequestParam("file") MultipartFile file) {
log.info("进入方法");
if (file.isEmpty()) {
return error(30000, "没有选择文件");
}
try {
//判断有没路径,没有则创建
String filePath = System.getProperty("user.dir") + "/src/main/resources/static/";
File targetDir = new File(filePath);
if (!targetDir.exists() && !targetDir.isDirectory()) {
if (targetDir.mkdirs()) {
log.info("创建目次乐成");
} else {
log.error("创建目次失败");
}
}
String fileName = file.getOriginalFilename();
File dest = new File(filePath + fileName);
log.info("文件路径:{}", dest.getPath());
log.info("文件名:{}", dest.getName());
file.transferTo(dest);
JSONObject jsonObject = new JSONObject();
jsonObject.put("url", "/api/upload/" + fileName);
return success(jsonObject);
} catch (IOException e) {
log.info("上传失败:{}", e.getMessage());
}
return error(30000, "上传失败");
}
4.2.5留言管理界面
管理员可以查看留言反馈列表中某个用户提交的留言反馈信息的详情并可以举行复兴操作;可以对通列表信息举行查询、重置和删除操作。其界面如下图4-12所示。
图4-14留言管理界面图
4.2.6网站公告管理界面
网站公告管理界面是管理员用来管理体系中的通知公告的界面。管理员可以通过该界面举行通知公告的创建、编辑、发布和删除等操作,以便向用户转达各种紧张信息、公告、更新或变乱等内容。其界面如下图4-13所示。
图4-13网站公告管理界面图
5体系测试
5.1测试目的
体系测试的目的是确保体系的功能完整、性能稳定,并验证体系是否符合预期的设计和需求。通过体系测试,可以发现和修复潜伏的错误和缺陷,进步体系的质量和可靠性。同时,体系测试还可以评估体系在不同条件下的性能表现,包括并发性能、响应时间和容错能力等。通过全面的体系测试,可以确保体系在正式上线前达到高品质的状态。
5.2 测试用例
体系测试包括:用户登录功能测试、网站公告查看功能测试、新闻信息添加功能测试、密码修改功能测试,如表5-1、5-2、5-3、5-4所示:
用户登录功能测试:
表5-1 用户登录功能测试表
测试用例编号
| 测试形貌
| 预期效果
| 实际效果
| 是否通过
| TC001
| 使用正确的用户名和密码举行登录
| 乐成登录体系,跳转到用户首页
| 登录乐成,跳转到用户首页
| 通过
| TC002
| 使用不存在的用户名举行登录
| 表现错误提示信息:用户名不存在
| 表现错误提示信息:用户名不存在
| 通过
| TC003
| 使用正确的用户名和错误的密码举行登录
| 表现错误提示信息:密码错误
| 表现错误提示信息:密码错误
| 通过
| TC004
| 不输入用户名和密码直接点击登录按钮
| 表现错误提示信息:用户名和密码不能为空
| 表现错误提示信息:用户名和密码不能为空
| 通过
|
网站公告查看功能测试:
表5-2 网站公告查看功能测试表
测试用例编号
| 测试形貌
| 预期效果
| 实际效果
| 是否通过
| TC001
| 打开网站公告页面,查抄是否可以大概正确展示网站公告列表信息
| 网站公告列表表现正确
| 网站公告列表表现正确
| 通过
| TC002
| 点击网站公告查看按钮,查抄是否能正常打开页面
| 网站公告详情页面表现正确
| 网站公告详情页面表现正确
| 通过
| TC003
| 查抄网站公告搜刮功能
| 根据关键字搜刮到干系网站公告并正确展示
| 根据关键字搜刮到干系网站公告并正确展示
| 通过
| 管理员添加新闻信息界面测试:
表5-3 管理员添加轮播图信息界面测试表
测试用例编号
| 测试形貌
| 预期效果
| 实际效果
| 是否通过
| TC001
| 使用合法的信息添加一个新的新闻信息
| 新闻信息乐成添加到体系
| 新闻信息乐成添加到体系
| 通过
| TC002
| 使用已存在的新闻信息名称添加一个新闻信息
| 表现错误提示信息:新闻信息名称已存在
| 表现错误提示信息:新闻信息名称已存在
| 通过
| TC003
| 添加新闻信息信息时不输入必填信息
| 表现错误提示信息:必填字段不能为空
| 表现错误提示信息:必填字段不能为空
| 通过
| TC004
| 使用不存在的关键字举行搜刮
| 搜刮效果为空
| 搜刮效果为空
| 通过
| 表5-4密码修改功能测试表
测试用例编号
| 测试形貌
| 预期效果
| 实际效果
| 是否通过
| TC001
| 输入正确的原密码和新密码举行修改
| 密码乐成修改
| 密码乐成修改
| 通过
| TC002
| 输入错误的原密码和新密码举行修改
| 表现错误提示信息:原密码错误
| 表现错误提示信息:原密码错误
| 通过
| TC003
| 不输入原密码和新密码直接点击修改按钮
| 表现错误提示信息:密码不能为空
| 表现错误提示信息:密码不能为空
| 通过
|
5.3 测试效果
通过编写基于Spring Boot架构的新闻推荐体系的测试用例,已经检测完毕体系测试包括:用户登录功能测试、网站公告查看功能测试、新闻信息添加功能测试、密码修改功能测试,通过这四大模块为基于Spring Boot架构的新闻推荐体系的设计与实现的后期推广运营提供了强力的技术支持。
第六章 结论
在基于Spring Boot架构的新闻推荐体系开发之前,需要先对用户的详细需求举行分析。包括体系的可行性分析、功能需求分析以及其他需求等。在可行性分析过程中,对体系实现的技术性、经济性等方面举行了分析。总体上证明了体系实施的可行性。
本文总结了基于Spring Boot架构的新闻推荐体系开发背景与意义,然后阐述了体系的详细业务需求,并根据体系需求对体系布局以及功能模块等举行了详细地设计,将整个体系分别为多个不同的功能模块。在分析体系功能需求时,对整个体系的总体架构以及功能模块等举行了分析,并选择符合的体系开发技术完成了对各个模块的开发工作。体系开发完成之后举行了摆设,同时举行了体系的测试过程,通过测试证明了体系在功能以及性能等方面都达到了预期的要求,具有较高的稳定性与可靠性。
参考文献
[1]雷欣,马宏琳,郑霖,等.基于SpringBoot的域名信息体系设计与实现[J].电脑知识与技术,2024,20(05):44-47.
[2]宣扬,彭明坤,蔡莉,等.基于协同过滤算法的新闻推荐体系的设计与实现[J].电脑知识与技术,2024,20(03):60-61+64.
[3]凌婷.协同过滤推荐算法研究进展[J].信息记录质料,2023,24(11):16-18.
[4]安丽达,王娟.推荐体系在新闻领域的研究综述[J].互联网周刊,2023,(18):80-81.
[5]孟祥福,霍红锦,张霄雁,等.个性化新闻推荐方法研究综述[J].计算机科学与探索,2023,17(12):2840-2860.
[6]张思淇.基于Hadoop的新闻推荐算法研究[D].沈阳工业大学,2023.
[7]叶长青.一种基于SpringBoot的影视内容推荐体系的设计与实现[J].电脑知识与技术,2023,19(01):85-87.
[8]徐晓君,朱成校.新闻体系的设计与实现[J].中国新通信,2022,24(18):61-63.
[9]张新彬.智能化推荐在新闻客户端中的应用与探索[J].传媒,2022,(12):74-75+77.
[10]袁昊.基于深度学习的新闻推荐体系设计与实现[D].中国科学院大学(中国科学院沈阳计算技术研究所),2022.
[11]吴世成.基于用户访问序列的新闻推荐体系设计与实现[D].北京邮电大学,2022.
[12]赵凤彬.基于用户举动的个性化新闻推荐体系的设计与实现[D].北京邮电大学,2022.
[13]黄志远.个性化新闻推荐研究[D].广东财经大学,2022.
[14]王浩.基于Spark框架的新闻推荐体系的设计与实现[D].北京邮电大学,2021.
[15]李树一.新闻推荐体系的设计与实现[D].黑龙江大学,2021.
[16]孟开元,岳宇航,曹庆年.新闻推荐体系研究综述[J].软件导刊,2021,20(01):249-252.
[17]Liang C .School Vehicle Management System Based on JAVA Language[J].Academic Journal of Computing Information Science,2023,6(9):
[18]Yang Y .Design and Implementation of Student Information Management System Based on Springboot[J].Advances in Computer, Signals and Systems,2022,6(6):
[19]Sunday O B ,Nduka O S . MySQL Database Server: Deploying Software Application to Enhance Visibility and Accountability [J]. Current Journal of Applied Science and Technology, 2023, 42 (4): 16-23.
[20]崔臣,宋甲旭.基于Spring Boot的校园二手交易体系研究[J].无线互联科技,2023,20(18):31-34.
致 谢
起首,我要感谢我的论文指导老师。在论文完成的整个过程中,指导老师始终给予我无微不至的关爱与指导。在论文写作的过程中,导师那耐烦过细的指导,以及提出的具有建设性的意见,都给予了我极大的帮助,让我受益匪浅。导师严谨的治学态度、敬业精神以及高水平的教学能力,都给我树立了追求卓越的范例,这对我以后的人生道路和学业成绩都产生了极大的积极影响。
此外,我还要感谢我班的同砚们,他们既是我的同学挚友,又是我的良师良朋。正是由于你们的支持和关怀,使得我在大学期间的学习和生存都变得非常充实。感谢那些在大学期间给予我帮助的所有老师和同砚们,是你们给予了我在学业道路上的前进动力。
当然,我也不能忘记我的父母,是他们用无私的爱抚养我成人。你们的养育之恩我将永生难忘,未来我一定会用我的成绩回报你们。在成长的道路上,我会不断努力,不负众望,用实际办法往返报你们对我的望。
点赞+收藏+关注 →私信领取本源代码、数据库
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |