毕业论文(设计)
校园论坛圈子及信息聚合系统的设计与实现
学位论文原创性声明
摘 要
随着社会的飞速发展,我们也进入了一个更加激烈的信息化时代。在信息化、时代化加快的同时,相应的也产生了更多零碎化的信息。以校园为例,通过对校园信息内容进行调查,发现存在许多校园信息存在零碎化、不集中等问题,这也导致了同学们在接收信息时会出现信息杂乱和不及时的现象,同时还有可能出现一些错误的信息传递。因此,面向学生群体实现校园论坛以及校内信息的聚合,可方便师生进行信息的有效查询以及资源下载。
本论文主要从校园论坛圈子及信息聚合出发,系统阐述了校园论坛圈子各模块的详细设计和基本形式等。校园论坛圈子主要是为同学们提供一个可以进行信息交流的平台,同学们可以在上面进行及时的信息交流和问题探讨,可以查看自己的发帖和其他人给与的回复,并且也可以在上面查看其他人的动态及评论,使得同学们可以进行便捷的交流。信息聚合部分主要是可以及时接收到学校官方发布的重要信息,目前主要根据信息分布零散存在的一些问题,我们采用信息聚合的方式进行改善,运用爬虫等技术进行信息聚合,从而进行优化,希望可以减少信息传递的误差。本论文提出的改善方案对信息聚合有一定的参考价值,同时可以做到资源最有效、最便捷和最优先的利用,希望可以为校园信息管理带来方便。
关键词:校园论坛;信息聚合;校园圈子;BBS;ASP.NET CORE;
DESIGN AND IMPLEMENTATION OF CAMPUS FORUM CIRCLE AND INFORMATION AGGREGATION SYSTEM
ABSTRACT
With the rapid development of society, we have also entered a more intense era of informatization. Along with the acceleration of informatization and modernization, more fragmented information has also emerged. Taking the campus as an example, through investigating the content of campus information, it was found that there are many problems with fragmented and non centralized campus information, which also leads to students receiving information in a disorderly and untimely manner, and may also result in some incorrect information transmission. Therefore, implementing campus forums and aggregating campus information for student groups can facilitate effective information retrieval and resource downloading for teachers and students.
This paper mainly starts from the campus forum circle and information aggregation, and systematically elaborates on the detailed design and basic form of each module of the campus forum circle. The campus forum circle mainly provides a platform for students to exchange information. Students can exchange information and discuss problems in a timely manner on it, view their own posts and replies from others, and also view other people's updates and comments on it, making it convenient for students to communicate. The information aggregation part mainly aims to receive important information released by the school in a timely manner. Currently, based on the scattered distribution of information, we have adopted information aggregation methods to improve it. We use technologies such as crawlers to aggregate information and optimize it, hoping to reduce errors in information transmission. The improvement plan proposed in this paper has certain reference value for information aggregation, and can achieve the most effective, convenient, and prioritized utilization of resources, hoping to bring convenience to campus information management.
KEY WORDS: forum; Information aggregation; ASP.NET Core
目录
1绪论
1.1研究背景和研究意义
1.2论文结构
2相关技术介绍
2.1使用技术与工具概况
2.2ASP.NET Core 概述
2.2.1ASP.NET Core
2.2.2.NET 6
2.3EntityFramework Core概述
2.4ASP.NET Core Identity概述
2.5Bootstrap概述
2.5.1Bootstrap简介
2.5.2Bootstrap特点
2.6MySQL 概述
2.6.1MySQL介绍
2.6.2MySQL特点
2.7 Visual Studio 概述
3系统可行性与需求分析
3.1系统可行性分析
3.1.1技术可行性分析
3.1.2经济可行性分析
3.1.3操作可行性分析
3.1.4法律可行性分析
3.2系统功能需求分析
3.2.1帖子的相关操作
3.2.2管理员的相关操作
3.2.3系统性能需求分析
3.2.4系统业务流程分析
3.3系统开发环境
4系统设计
4.1系统结构设计
4.1.1系统总体功能结构
4.1.2用户功能结构
4.1.3管理员功能结构
4.2系统数据库设计
4.2.1数据库 E-R 图设计
4.2.2数据库文档设计
5系统实现
5.1用户模块
5.1.1用户登录与注册的设计与实现
5.1.2用户信息查看
5.2论坛模块实现
5.2.1发帖
5.2.2帖子评论
5.2.3点赞收藏与转发
5.3朋友圈子模块
5.3.1动态
5.3.2关注和留言
5.4信息聚合模块
5.5管理模块
5.6其它
5.6.1未读消息
5.6.2响应式设计
6系统测试
6.1测试目的
6.2测试系统环境
6.3功能测试
6.3.1系统登录功能测试
6.3.2用户发帖功能测试
6.3.3资讯聚合测试
7总结
参考文献
致谢
1绪论
1.1研究背景和研究意义
在互联网大数据时代,动态性、交互性和便捷性的论坛已经成为其中最丰富、最自由的网络信息资源,也是现代人们最受欢迎的方式之一。计算机的普及以及计算机网络技术的应用,使得现在的人们能够有机会接触到比以往更多的知识。作为一个以传播知识为主要职能的学校,建立一个自己的校园论坛圈子及信息聚合系统是十分必要的事情,这不仅能使更多的同学享用宝贵的教育资料源,同时对于提高学生自学能力和学术问题方面的探讨,有相当大的帮助[1-2]。
由于现在国民经济快速的发展,我们接收信息的方式也越来越多样化,对信息服务的快捷、便利性要求也越来越高,从而对信息的建设与管理也提出了更高的要求。由于校园信息内容的不断增加和发展,所以校园信息管理难度也越来越大。为了适应和推动校园信息的发展,针对校园信息存在的零碎化、不集中等问题,搭建校园论坛圈子及信息聚合,可以有效实现信息共享,并且学校可以整合学校服务到这个网站上面。由于传统的校园信息管理方式存在着很多方面的不足,比如实时性差、信息散乱和共享不及时等问题。所以推出校园论坛圈子及信息聚合系统,可以让同学们接收到的信息变得更简单一些,为同学们的学习和生活提供更多的便利,同时还可以进行一些经验交流和学术方面的探讨,实现资源与经验的共享[3-5]。
希望可以设计出一个平台,使得学生之间也可以通过这个平台进行交流和进行学术分享。教师亦可经由该平台获取有关学生对于校园建设和教学等领域的想法和态度等思想动态[6]。此外,教师还可以利用校园论坛与学生就相关专业领域的学术问题进行深入交流和研讨,以提高教学质量和学术水平。
根据这种现实需要,设计制作一个校园论坛圈子及信息聚合系统便成为一件非常有价值的工作。同时希望可以做到资源最有效、最便捷和最优先的利用,主要的目的是让同学们在快节奏的今天,能够在遇到困难时,及时向老师或其他同学寻求帮助[7]。并且使同学们可以通过本论坛进行便捷的相互交流,从本论坛中获取一些最新的信息和最新的动态。所以我们需要一个综合类的信息交流平台,本设计是一款能集合现有的校园服务,生活信息、科技信息、论坛帖子和校内交友圈子功能的校园网站。校园论坛圈子及信息聚合进行管理具有传统管理模式不可比拟的优点,它凭借其信息更新速度快、信息存储量大、安全性高、应用简便等特点为校园信息的管理带来了极大的方便,发挥越来越重要的作用[8-11]。
1.2论文结构
本论文主要共分为六个部分,各部分的主要内容如下:
第1章绪论:主要介绍了这个项目的研究背景、研究意义以及论文的整体结构。
第2章相关技术介绍:主要介绍了该系统所使用的主要技术,包括前端技术、后端技术、数据库以及所用的开发工具。
第3章可行性分析与需求分析:探讨了系统在技术、经济、商业、操作等多个方面的可行性;同时,从功能、性能、数据库等多个角度细致分析了系统的需求。
第4章系统设计:包括系统的功能结构设计和数据库设计。
第5章系统实现:从数据库、用户模块、信息聚合模块、论坛模块、圈子模块和管理模块六个方面阐述了系统的具体实现过程。
第6章系统测试:通过用例测试对系统进行了验证。
第7章总结:对系统实现过程进行了总结,并明确了进一步的改进思路。
2相关技术介绍
2.1使用技术与工具概况
本项目的目标是以ASP.NET Core为Web框架,MySQL为数据库设计并实现Web端MVC应用。开发过程中使用的具体技术及工具如表 21所示。
工具类型 | 工具名称 |
软件架构 | MVC |
系统结构 | B/S |
开发工具 | Microsoft Visual Studio、VS Code |
开发语言 | C#、Python、JavaScript |
数据库 | MySQL |
ORM | EntityFramework Core |
服务端基础环境 | .NET 6 |
服务端框架 | ASP.NET Core |
身份验证权限框架 | ASP.NET Core Identity |
前端框架 | Bootstrap |
前端包管理器 | Libman |
后端包管理器 | NuGet |
其他 | jQuery layer HtmlAgilityPack |
2.2ASP.NET Core 概述
2.2.1ASP.NET Core
ASP.NET Core作为一款高性能的开源框架,被设计为跨平台应用,旨在支持开发符合当下现代理念以及互联网平台需求的Web应用程序。ASP.NET Core 是基于 ASP.NET 4.x 系列重新设计的。通过架构调整,该框架已经转变为更具模块化、轻量级、开源性、可扩展性、高性能和跨平台特性的web框架[12]。
它有如下特点:
(1)ASP.NET Core框架可以跨平台使用
ASP.NET Core 应用程序可以托管在 IIS、Apache、Docker、HTTP.sys 和 Nginx 上,配合自带的 Kestrel 甚至可以把自己托管在进程中(自托管)。
(2)Web API和MVC技术的统一
在传统的ASP.NET中,MVC风格的项目和 Web API 项目需要依赖不同的组件并分别继承不同的基类,而在使用ASP.NET Core开发MVC风格的Web应用程序和Web API时,仅需继承Controller基类并返回IActionResult,这种开发方式可以显著提高开发效率并增加接口的可复用性[13]。
(3)更强的可测试性
通过内置的依赖注入、用于创建 Web应用程序、Web API的统一编程模型,可以轻松地对 ASP.NET Core 应用程序进行单元测试和集成测试。
(4)轻量、高性能的模块
ASP.NET Core 中提供了模块化的中间件,在请求(Request) 和响应(Response)的管道中就使用了中间件。它还包含了其他丰富的内置中间件。我们还可以通过自定义中间件来实现独特的业务功能。
(5)开源
由.NET团队与社区中众多的开源开发者共同参与维护。因此,ASP.NET Core会不断发展,而且其背后的庞大社区会持续地改进并帮助修正错误,这意味着我们会拥有更安全、质量更好的软件[14]。
其结构如图 21所示。
图 21 ASP.NET Core 结构
2.2.2.NET 6
微软发布的.NET 6是首个由该公司官方开发的跨平台(Windows、macOS 和 Linux)应用程序开发框架(Application Framework),具有以下特点[15-16]:
(1)跨平台
读者可以创建一个.NET Core应用程序,可分别在Windows、Linux和macOS上运行。
(2)统一性和兼容性
利用统一的.NET标准库,使用相同的代码兼容所有平台,并使用相同的语言和工具复用读者的技能,降低学习成本。
(3)开源
.NET 6平台是开源的,它的运行库、库、编译器、语言和工具的源代码都在GitHub上开源,接受代码贡献,并且使用宽泛的MIT和Apache 2开源许可证。
(4).NET基金会官方支持
.NET Core由微软的.NET 基金会创立后交付给社区独立运营,由基金会提供对.NET 5 的支持。
其结构如图 22所示。
2.3EntityFramework Core概述
对象-关系映射(Object-Relational Mapper,ORM)技术使得开发人员得以通过业务对象来操作数据库。开发者常常依赖应用程序中的业务对象,而ORM则能够负责生成符合底层数据库语法规范的SQ语句。简而言之,ORM减少了开发人员编写的代码量,如果不使用ORM, 则通常需要大量访问数据库的代码或者SQL语句[17]。
Entity Framework Core简称EF Core,为一款ORM框架,被认为是一款轻量级、可扩展且开源的软件。与.NET Cor具有类似之处,EF Core同样支持在Windows、macOS和Linux等多平台上运行。EF Core是微软推荐的官方数据访问平台。
我们可以通过一个例子来理解ORM和EF Core的关系。比如在开发一个学校管理系统过程中,会有像Student、Department和Course这样的类出现在应用程序代码中。如果没有像EF Core这样的ORM,则必须编写大量的代码来访问数据库,进而存储和检索底层数据库中的学生和部门数据。在10年前,我们使用的开发方式是通过ADO.NET手写连接SQL数据库的帮助器,这样做不但低效,而且很不安全,容易出现SQL注入漏洞的问题。比如,要查询、添加、更新或删除底层数据库表中的数据,必须在应用程序中编写代码,以生成底层数据库可以理解的SQL语句。此外,当数据被读取并需要显示到应用程序时,我们再次编写自定义代码将数据库数据映射到模型类,如Student、Department和Course等,这是几乎在每个应用程序中都需要进行的很常见的任务,而EF Core可以完成所有这些琐事,从而为我们节省大量时间。ORM是一种机制,它作为应用程序代码与数据库之间的纽带,减少了在无ORM框架的情况下编写大量代码(如SqlHelper.cs)以访问数据库的需求。
EF Core支持Code First方法和Database First(DB First)方法。但是,目前EF Core对Database First方法的支持非常有限。使用Code First方法,需要先创建应用程序所需要的领域类,如Student Major、Order等领域类,以及从Entity Framework DbContext派生的特殊类。基于这些领域类和DBContext类,EF Core会为我们创建数据库和相关表。图23给出了EF Core Code First代码先行关系图。
图 23 代码先行
2.4ASP.NET Core Identity概述
ASP.NET Core Identity是一款身份验证系统,其早期版本称为Membership。该系统允许用户进行账户的CRUD操作,包括账号验证、身份验证、授权、密码重置以及双因子身份验证。此外,它还支持微软、Facebook、Google等第三方登录服务商,提供了丰富的可扩展API。
2.5Bootstrap概述
2.5.1Bootstrap简介
Bootstrap是一款免费的、开源的CSS框架,专注于响应式设计和移动优先的前端Web开发。该框架提供基于CSS和JavaScript的设计模板,用于排版、表单、按钮、导航以及其他界面组件。Bootstrap的初衷在于消除前端框架在命名、样式和页面设计方面的问题,并统一各类命名方式,使前端页面更加简洁和直观。此外,Bootstrap还支持响应式布局,有助于提升Web应用程序的开发效率。
2.5.2Bootstrap特点
Bootstrap是一个集中于优化信息网页(相对于Web应用程序)开发的HTML、CSS和JS库。引入Bootstrap到Web项目中的主要目的在于将其提供的颜色、大小、字体和布局选择应用于项目中,因此,关键要点在于开发人员能否找到符合其喜好的样式选择。一旦引入到项目中,Bootstrap便会为所有HTML元素提供基本的样式定义。在Web浏览器中,散文、表格和表单元素的视觉表现被统一处理,另外,开发者可基于Bootstrap提供的CSS类进一步个性化内容呈现。例如,Bootstrap提供了不同主题色系的表格、页面标题、引用标注和醒目文本等选项[18]。
Bootstrap还提供了几个jQuery插件形式的JavaScript组件,这些组件增加了额外的用户界面元素,比如对话框、工具提示和轮播。每个Bootstrap组件包含特定的HTML结构和CSS声明,并在一些情况下包含JavaScript代码,同时它们也扩展了一些已有界面元素的功能,如自动完成输入字段。
Bootstrap最显著的特点在于其布局组件,这些组件对整个页面产生影响。其中最基本的布局组件被称为“容器”,用于容纳页面中的所有其他元素。开发者可以根据需要选择固定宽度容器或流体宽度容器。尽管流体宽度容器会填充整个页面宽度,而固定宽度容器则提供五个预定义的固定宽度选项。一旦容器设置完成,其他Bootstrap布局组件会通过定义行和列来实现CSS Flexbox布局。
Bootstrap的发布版本为一个CSS文件和三个JavaScript文件的形式,可便捷地集成至不同项目中。相较之下,Bootstrap的源码版允许开发者进行更深度的定制和代码优化。该源码版具有模块化特性,即开发者可排除不必要的组件、应用自定义主题,并修改未编译的Sass文件[19]。
Bootstrap作为出色的前端框架,具备多项优势:兼容性优良、响应式布局设计、页面网格化处理、丰富的类库支持以及基于Less等特性。另外,在进行前端开发时,使用Bootstrap的预处理脚本可以便捷地利用其自带样式,也能够根据需求选择使用Bootstrap源码或其他方式进行样式定制。正是这些优势,使得用户能够迅速掌握框架,高效便捷地进行开发。
2.6MySQL 概述
2.6.1MySQL介绍
一款数据库软件具有移植功能表明其具备广泛应用的潜力,例如数据库是一个被广泛应用的数据库软件,其功能完善,适用于一般企业或个人使用,并且可在多种编译器上进行编译测试。
MySQL作为一种具备安全性、跨平台性和高效性的数据库系统,紧密结合了PHP、Java等主流编程语言。MySQL 的代表标志是一只名为 Sakila 的海豚,象征着该数据库的速度、表现、准确性以及卓越特性[20]。
当前,MySQL广泛应用于中小型互联网网站。其小巧、高效和开源的优势,使许多企业选择采用MySQL数据库,以降低整体拥有成本。
MySQL 数据库以高效运行速度著称,是当前速度最快的 SQL 语言数据库之一,在诸多功能上胜过其他数据库。此外,MySQL 数据库以免费提供,用户可以通过网络免费获取,无需支付任何费用。
2.6.2MySQL特点
(1)功能强大
MySQL的数据库系统提供了多样的存储引擎,每种引擎具有不同的特点,适用于各种不同的应用场景。用户可以根据需求选择最为合适的存储引擎,以实现最佳的性能表现。这些存储引擎能够胜任处理每日访问量达数十亿次的高频Web搜索网站等高强度工作负荷。同时,MySQL支持事务处理、视图、存储过程和触发器等功能。
(2)支持跨平台
MySQL支持超过20种不同的开发平台,如Linux、Windows、FreeBSD、IBMAIX等,这种广泛的支持使得程序在各种平台上可以轻松移植,无需对程序进行任何修改。
(3)运行速度快
MySQL具有显著的高速特性,包括采用了高效的B树磁盘表(MyISAM)和索引压缩技术,在连接操作中实现了优化的单扫描多连接,以及运行速度极快的SQL函数,该函数经过高度优化的类库实现。
(4)支持面向对象
PHP语言支持多种编程方式,包括纯面向对象、纯面向过程以及面向对象与面向过程混合的编程方式。
(5)安全性高
灵活而安全的权限和密码系统可以确保主机进行基础验证。在与服务器建立连接的过程中,所有密码传输均采用加密方式,以保障密码的安全性。
(6)成本低
MySQL数据库是一款免费的数据库产品,可在网络上直接下载。
(7)支持各种开发语言
MySQL为多种常见的编程语言提供支持,通过其API函数为这些编程语言提供了丰富的功能。
(8)数据库存储容量大
通常情况下,MySQL数据库的最大有效容量受操作系统文件大小限制,而非MySQL内部的规定。InnDB存储引擎会将InnDB表存在单独的表空间中,该表空间可由多个文件构成,支持最大容量达到64TB,便于处理包含数以万计记录的大型数据库。
(9)支持强大的内置函数
PHP语言内置了丰富的函数库,涵盖了几乎所有Web应用开发所需的功能,包括但不限于数据连接、文件上传等。此外,PHP还支持多种扩展库,如MySQL等,为开发者提供了快速开发Web应用的便利。
2.7 Visual Studio 概述
Microsoft Visual Studio是由微软公司开发的一款集成开发环境(IDE),供开发计算机程序以及网站、网络应用程序、网络服务和移动应用程序使用。Visual Studio利用微软的软件开发平台,如Windows API、Windows Forms、Windows Presentation Foundation、Windows Store和Microsoft Silverlight,支持生成本机代码和托管代码。
Visual Studio拥有一个结合了IntelliSense(代码智能提示)和代码重构功能的代码编辑器,同时它还内置了调试器,可进行源代码级和机器级的调试。此外,还包含了代码分析器、GUI应用程序构建设计器、Web设计器、类设计器和数据库模式设计器等内置工具。该软件可以接受几乎在各个层面都能扩展功能的插件,这些插件可以包括对源代码控制系统(如Subversion和Git)的支持,并增加新的工具集,例如专为特定领域语言设计的编辑器和可视化设计器,或用于软件开发生命周期其他方面的工具集(如Azure DevOps客户端:团队资源管理器)。
Visual Studio支持36种不同的编程语言,允许代码编辑器和调试器在特定语言服务存在的前提下,以不同程度支持几乎所有编程语言。其中内置的语言包括C、C++、C++/CLI、Visual Basic .NET、C#、F#、JavaScript、TypeScript、XML、XSLT、HTML和CSS。其他编程语言如Python、Ruby、Node.js以及M等可通过插件实现支持,而之前还曾支持Java(和J#)[17-19]。
3系统可行性与需求分析
3.1系统可行性分析
3.1.1技术可行性分析
从技术可行性的方面看,该研究采用ASP.NET Core框架进行开发,服务器端采用.NET 6服务,具有开源性,可实现跨平台部署。同时,前端界面基于ASP.NET Core实现,具备多浏览器多终端兼容性,开发完成后可在几乎所有平台进行部署与访问,具备技术上的可行性。目前,论坛技术已经较为成熟。现在市场上已经出现通用的社区论坛软件系统。如 discuz, wordpress,phpwind。技术上 C#的开发就能开发出一整套论坛系统。所以系统在技术上不难实现。
3.1.2经济可行性分析
从经济可行性的方面来看,系统可以在任意平台通过开源软件下载配置开发环境进行开发,且后续开发过程易上手,开发周期较短,经济需求较低。从短期成本与长远利益的角度来看,本项目具有经济可行性。前期对系统进行技术编码成本低,可以承受。但在后期服务器的租用费用,技术问题、安全维护等后期的维护工作成本较高,但后期可以引入广告收益,所以在一定程度上具有经济可行性。
3.1.3操作可行性分析
系统的设计符合日常论坛形式,与我们日常所使用的网站的操作基本一致,不存在复杂的问题。所以操作可行。数字化平台的方式更加具有可操作性、便捷性、可发展性。由此看来,本项目具有操作可行性。
3.1.4法律可行性分析
从法律的角度分析,本项目采用的均为经过开发者或开发团队发布、并具备国际版权协议的开源软件或技术,且所有下载和配置行为均在合法渠道进行,且受到中国法律监管。基于这些软件和技术开发的平台符合中国的法律法规,合法运营且合规,不存在知识产权侵犯等违法行为,因此本项目在法律层面具备可行性。
3.2系统功能需求分析
本系统用于校内学生交流以及校内信息聚合。所以我们的系统在功能上首先需要有帖子功能,包括看帖、发帖功能,还要实现登录注册功能。最后还要实现转发、评论、收藏的功能。在数据方面,需要对数据进行隐私化处理和可行性处理,即数据量大时,要保证数据的安全性和系统的稳定性。
下面主要从帖子的操作和管理员的操作进行论述。
3.2.1帖子的相关操作
该系统需要一个主页面来展示帖子的内容;其次还需要存放数据的地方,我们选择把数据都存放在数据库中。另外,还要有对帖子的操作包括编辑、修改、删除、转发、评论和收藏,这些操作的数据均存在数据库中。
3.2.2管理员的相关操作
管理员需要一个单独的页面对帖子进行管理,需要对帖子进行管理和用户管理、话题管理、及反馈管理。并且本系统还会有一个反馈页面,即用户对本系统进行反馈,所以管理员还需要对系统进行的反馈进行回复。
3.2.3系统性能需求分析
开发过程中不合标准的代码与逻辑结构可能会有潜在的不确定性。在某些情况下可能会造成不良的用户体验,减少用户粘度,对平台声誉造成不良影响。
(1) 响应时间
在开发者角度,开发过程中通过Visual Studio 编译与发布的时间应在15秒内,在热更新中应不超过800毫秒。
在用户角度,不包含用户在运营商线路上传输损耗,前端响应时间不应超过 300 毫秒,后端响应时间不应超过500毫秒,系统总体响应时间应在1秒内。
(2) 工作负载
从用户和开发者角度,平台应在系统中尽量做到低负载的同时拥有高性能,能承受大量的并发访问数据库,在保持稳定的情况下尽量减少平台对服务端与用户端的负载。
(3) 可拓展性
随着时间推移,系统必然会涉及到业务更新与发展,在保持稳定的情况下,应保持项目的可拓展性与可维护性。
3.2.4系统业务流程分析
本系统自用户进入主页面开始,就进入到了论坛系统的主页面,能看到各种帖子,也能查看各种帖子,但是想要发表帖子或者是先要转发、收藏都必须要先登录。在主页面的信息栏上还有校内咨询和动态的功能页面。点击后进入各自的页面。并且可以在自己的个人中心查看自己的收藏和发帖,并且查看别人对自己帖子的回复。
3.3系统开发环境
(1) 运行环境需求
操作系统:Windows 11
开发工具:Microsoft Visual Studio
开发技术:ASP.NET Core
数据库:MySQL
(2) 硬件环境需求
具体硬件环境需求如下:
处理器:双核及以上 X86 架构处理器,主频 2.1GHz 以上
内存:4G DDR3 内存及以上。
硬盘:250G SATA 固态硬盘及以上。
4 Python爬虫技术在信息聚合中的应用
4.1 爬虫技术基础与环境配置
Python爬虫技术,以其丰富的库资源和易学性,在信息聚合任务中大放异彩,成为从网络海洋中高效捕捞信息的关键工具。在构建校园论坛圈子及信息聚合系统这一项目中,Python爬虫的部署旨在自动搜罗校园内外网络空间里的最新信息,将这些分散的资讯汇聚一堂,构建一个综合性的信息获取平台,使用户得以轻松触及校园生活的每一个角落。
构建这样一个强大的信息捕获系统,首当其冲便是配置一个适宜的开发环境。本项目选用了Python 3.9作为开发语言的基础,此版本平衡了性能与兼容性,为爬虫任务提供稳定支撑。为了实现网页数据的高效抓取,我们引入了requests库,它以简洁的API设计,使得发送HTTP请求变得轻而易举。而数据解析方面,我们依靠BeautifulSoup库来深入HTML结构,抽丝剥茧般地提取所需信息,加之lxml库作为解析加速器,进一步增强了数据解析的效率与精度。
考虑到爬虫在实际运行中可能遭遇的挑战,如网页响应慢、数据量大等情况,我们引入了异步处理机制。通过aiohttp与asyncio库的联合使用,实现了并发请求,显著提升了爬取速度,使得面对大量数据的抓取任务也能游刃有余。异步技术的加入,不仅减少了等待时间,也增加了爬虫的稳定性,即便在网络波动环境下,也能保持较高的数据获取效率。
所有这些技术组件的集成与配置,均在Anaconda虚拟环境中完成。Anaconda作为强大的包管理和环境管理系统,为项目创建了一个隔离的开发沙箱,确保了开发过程中所依赖的工具和库版本的一致性,避免了因环境冲突导致的开发问题。通过这样的环境配置,我们不仅为Python爬虫技术的应用奠定了坚实的基础,也为后续的开发与维护工作铺平了道路,确保了项目的顺利进行。
4.2信息采集与处理策略
在"校园论坛圈子及信息聚合系统的设计与实现"项目中,信息采集与处理策略是整个系统高效运作的基石。为了确保信息的全面性和时效性,我们采取了针对性的Python爬虫技术来自动化地从各类网络源抓取校园相关的资讯。这一过程不仅限于学校官方渠道,还包括学生社团、学术论坛等活跃信息源,以期覆盖更广泛的学生兴趣点和需求。
信息采集策略侧重于灵活性与智能识别。爬虫程序根据预定义的规则动态适应不同网站结构,利用XPath和CSS选择器精确定位目标数据,如帖子标题、内容、作者信息等。对于动态加载的内容,集成Selenium工具模拟真实用户操作,绕过JavaScript渲染障碍,确保数据完整性。为尊重网站资源与遵守Robots协议,爬虫设定合理的访问频率,减轻目标服务器压力,同时采用随机用户代理池规避潜在的反爬措施。
信息处理阶段则注重数据的净化与整合。原始数据经过去重、去噪处理,消除无关的HTML标签、空白字符,确保数据干净、规范。利用哈希算法对比确保新抓取信息的唯一性,避免重复存储。清洗后的数据根据其属性分类,存储至MySQL数据库中,如帖子、用户行为记录等,通过合理索引设计优化查询效率。对于敏感信息,采取加密处理,保护用户隐私安全。
整体而言,信息采集与处理策略旨在构建一个高效的信息供应链,从源头的智能抓取,到数据的深度清洗,再到最终的结构化存储,每一步都为用户提供了一个信息丰富、更新及时、易访问的校园信息聚合平台。
4.3信息聚合与展示优化
信息聚合与展示优化环节在校园论坛圈子及信息聚合系统中至关重要,它直接关联到用户体验与系统效能。通过Python爬虫技术获取的信息需经过精细处理与智能聚合,而后以直观、友好的形式展现在用户面前。
信息经过初步筛选与去重后,进入高级处理阶段。这里,我们利用自然语言处理技术对文本进行语义分析,归类信息类别,如学术讲座、社团活动、校园通知等,使信息有序化。同时,采用情感分析技术对帖子内容情感倾向进行标注,帮助用户快速识别热门、正面的讨论主题。信息聚类算法则把相似主题的帖子合并,减少信息冗余,提升浏览效率。
在数据整合的基础上,我们设计了一套高效的索引策略,确保用户查询时能迅速从庞大的信息库中检索出所需内容。利用倒排索引、全文检索等技术,即使是模糊关键词也能精准匹配到相关信息。此外,引入标签云、热点图等可视化工具,直观展示信息热度与趋势,引导用户发现热点。
展示优化方面,我们采用了响应式设计,确保信息页面在不同设备上均能良好显示,无论是在PC端还是移动设备上,用户都能享受一致的浏览体验。页面布局清晰,导航简洁明了,通过Ajax技术实现异步加载,减少页面刷新,提升交互流畅度。用户界面融入了个性化推荐模块,基于用户行为分析,推送定制化内容,增强用户黏性。
此外,重视用户参与度的提升,设置了评论、点赞、分享等交互功能,通过用户反馈循环优化信息质量。系统还设有举报与反馈机制,对不良信息及时处理,维护健康的信息生态环境。
4系统设计
4.1系统结构设计
4.1.1系统总体功能结构
系统主要包括用户模块、论坛模块、信息聚合模块、圈子交友模块和管理模块五部分。
其中用户模块的主要功能有用户的注册、登录、个人信息管理等。论坛模块主要有发帖、评论、转发、收藏,以及话题分类、帖子排行、统计信息等。信息聚合模块聚合了临沂大学信息科学与工程学院的信息,并把它分为了通知公告、下载专区、学院风采、新闻快讯几个部分。圈子交友模块中主要实现了动态查看、留言板、关注等功能。管理模块实现了帖子管理、用户管理、话题管理、反馈管理的功能。
平台总体的功能结构图如下图 41系统的总体功能结构图所示。
4.1.2用户功能结构
系统的用户功能结构中具体的功能有:登录与注册管理功能中包括了注册账户, 登录账户等功能;个人信息管理功能,其中有用户昵称、头像、邮箱、个人简介的修改; 消息功能有关注通知、回帖通知和留言通知。
(1)用户登录管理
在用户进入平台后,平台会对用户历史登录信息进行验证。如果用户此前没有登陆过或登录已过期,平台会引导用户进入登录界面进行用户登录。用户输入用户名与密码后, 点击登录,系统会提交登录信息进行登录验证。
如登录成功,即可进入平台首页。登陆失败则退回用户登录界面提示用户进行重新登录。如果用户尚未注册,平台会引导用户进行注册,并引导用户进入注册界面进行注册。用户注册完成后,可切换至登录界面进行登录
用户登录管理流程图,如图 42所示。
(2)个人信息管理
用户登录后,可以点击编辑个人信息,进入用户信息编辑界面。用在这可以对个人的昵称、头像、邮箱以及个人简介进行修改。
(3)信息功能管理
用户在论坛上发布的帖子在收到评论、用户个人被关注以及留言信息系统在界面显示有未读信息。在动态界面更可以看到自己帖子的转发情况和自己转发的帖子。
4.1.3管理员功能结构
管理员具有对帖子、用户、话题、反馈进行管理的权限。
帖子管理中管理员可以对帖子进行编辑、删除、置顶以及优质(优质的贴将会置顶并标记上优质帖子的标识),用户也可以在这里查看帖子内容、发布时间、回复时间以及回复量多少;用户管理中记录了用户的个人信息(用户头像、用户昵称和邮箱),还可以查看用户的注册时间和最近一次登陆时间,管理员也可以对用户的信息进行删除;话题管理中管理员可将用户发布的帖子进行分类,分成若干个父类,其中有热点、寻物、表白等分类,官员也可以新增分类来更加完善的细化帖子分类;反馈管理则类似于一个管理员与用户的交流平台,用户可以在这里反馈本平台的不足以及、平台提出的建议和平台上相关内容的讨论。
4.2系统数据库设计
4.2.1数据库 E-R 图设计
以数据库信息请求为中心,考虑的是用户需求在数据库中提取信息的内容和属性,包括用户登录注册、浏览帖子和发布帖子等过程中有效引导用户的交互界面设计,确保用户数据及需求能够及时完整地传递给平台其他用户,从而便于用户进行帖子管理。
从数据库的处理要求方面考虑,指的是用户要求完成的数据处理功能,即在发布帖子、回复帖子时,能够对相应信息进行适当的处理。能够进行帖子、话题的锁定或编辑、删除等操作。各个界面的功能模块要保持稳定和高效,对于数据处理具有相应的要求,以确保数据能够完整、迅速地展示给平台所有用户。
数据库设计是根据真实使用场景的需求而展开设计的。数据库中的 E-R 关系如图 43所示。
4.2.2数据库文档设计
本项目设计主要用于学生,基于 ASP.NET Core 开发。对于平台上的管理员来说,需要平台能够进行帖子管理、话题管理、反馈管理、用户管理等。对于平台上的用户来说,则需要平台具有帖子查看、发评论、发帖子,查看常用网站的资讯和信息,与同好交流互关留言等功能。
因此,平台主要分为用户与管理员两个角色,项目中数据库选择的是MySQL数据库进行数据的存储和管理。本项目数据库中主要有12个表,分别为用户表,角色表,用户角色表,帖子表,话题表,回复表,点赞表,收藏表,留言表,关注表,反馈表,动态表。
(1)用户表
用户表(Users),是用来存储用户账户信息的表,主要包括用户标识符、用户名、Email、QQ、手机号、密码等属性。密码经过加密后存储。用户表的具体设计如表 41所示。
表 41 用户表
描述 | 字段名 | 数据类型 | |
1 | 用户标识符 | Id | nvarchar(450) |
2 | 用户名 | UserName | nvarchar(256) |
3 | | | nvarchar(256) |
4 | | | nvarchar(256) |
5 | 个人简介 | Profile | nvarchar(max) |
6 | 手机号 | Phone Number | nvarchar(max) |
7 | 创建时间 | CreateOn | datetime2 |
8 | 密码 | PasswordHash | nvarchar(max) |
(2)角色表
角色表存储了系统中的用户角色,不同角色对应不同权限。角色表的具体设计如表 42 所示。
序号 | 描述 | 字段名 | 数据类型 |
1 | 角色标识符 | Id | nvarchar(450) |
2 | 角色名 | Name | nvarchar(256) |
(3)用户角色表
用户角色表存储了系统中的用户所对应的角色,不同用户对应不同角色,不同角色对应不同权限。用户角色表的具体设计如表 43所示。
序号 | 描述 | 字段名 | 数据类型 |
1 | 用户标识符 | UserId | nvarchar(450) |
2 | 角色标识符 | RoleId | nvarchar(450) |
(4)帖子表
帖子表(Topic),是用来存储帖子信息的表。帖子表具体设计如表 44所示。
序号 | 描述 | 字段名 | 数据类型 |
1 | 帖子标识符 | Id | int |
2 | 话题标识 | NodeId | int |
3 | 用户ID | UserId | nvarchar(max) |
4 | 标题 | Title | nvarchar(max) |
5 | 内容 | Content | nvarchar(max) |
6 | 置顶 | Top | nvarchar(max) |
7 | 类型 | Type | nvarchar(max) |
8 | 浏览人数 | ViewCount | Int |
(5)话题表
话题表(topicnode),是用来存储话题的信息。具体设计如表 45所示。
序号 | 描述 | 字段名 | 数据类型 |
1 | 话题标识 | Id | Int |
2 | 父节点名 | ParentId | nvarchar(max) |
3 | 节点名 | NodeName | nvarchar(max) |
4 | 名称 | Name | nvarchar(max) |
5 | 描述 | Description | nvarchar(max) |
6 | 顺序 | Order | Int |
7 | 创建时间 | CreateOn | nvarchar(max) |
(6)回复表
回复表(topicreply),是用来存储回复记录,主要包括回复标识符、主题标识符、回复者标识符、创建时间等。具体设计如下表 46所示。
序号 | 描述 | 字段名 | 数据类型 |
1 | 回复标识符 | Id | Int |
2 | 主题标识符 | TopicId | Int |
3 | 回复者标识符 | ReplyUserId | nvarchar(max) |
4 | 回复邮箱 | ReplyEmaiL | Datetime2 |
5 | 回复内容 | ReplyContent | Datetime2 |
6 | 创建时间 | CreateOn | Datetime2 |
(7)点赞表
点赞表(topicgood),是用来存储点赞记录,主要包括点赞标识符、点赞、点赞人昵称等。具体设计如下表 47所示。
序号 | 描述 | 字段名 | 数据类型 |
1 | 点赞标识符 | Id | Int |
2 | 点赞 | TopicIdGood | Int |
3 | 点赞人昵称 | UserGoodId | nvarchar(max) |
(8)收藏表
收藏表(topicstar),是用来存储收藏记录,主要包括收藏标识符、收藏、收藏者昵称等。具体设计如下表 48所示。
序号 | 描述 | 字段名 | 数据类型 |
1 | 收藏标识符 | Id | Int |
2 | 收藏 | TopicIdStar | Int |
3 | 收藏者昵称 | UserIdStar | nvarchar(max) |
(9)留言表
留言表(leavetalk),是用来存储留言记录,主要包括留言标识符、被留言人昵称、留言者昵称等。具体设计如下表 49所示。
序号 | 描述 | 字段名 | 数据类型 |
1 | 留言标识符 | Id | Int |
2 | 被留言人昵称 | LeaveById | Int |
3 | 留言者昵称 | LeaveErId | nvarchar(max) |
4 | 标题 | Title | Datetime2 |
5 | 内容 | Content | Datetime2 |
(10)动态表
动态表(active),是用来存储动态信息,主要包括动态标识符、动态名称、相关类型纪、动态创建时间等。具体设计如下表 410所示。
序号 | 描述 | 字段名 | 数据类型 |
1 | 动态标识符 | Id | Int |
2 | 动态名称 | TypeOfActiveId | Int |
3 | 相关类型 | RelatedType | nvarchar(max) |
4 | 相关节点 | RelateId | Datetime2 |
5 | 内容 | Content | bit |
6 | 动态创建时间 | ActiveCreateTime | nvarchar(max) |
(11)关注表
关注表(Follows),是用来存储关注记录,主要包括关注标识符、关注者昵称、创建时间等。具体设计如下表 411所示。
序号 | 描述 | 字段名 | 数据类型 |
1 | 关注标识符 | Id | Int |
2 | 关注者昵称 | FollowErUserId | Int |
3 | 创建时间 | CreateTime | Datetime2 |
(12)反馈表
反馈表(Feedbacks),是用来存储反馈信息记录,主要包括反馈标识符、反馈形式、反馈者昵称、反馈连接等。具体设计如下表 412所示。
序号 | 描述 | 字段名 | 数据类型 |
1 | 反馈标识符 | Id | Int |
2 | 反馈形式 | FeedStyle | Int |
3 | 反馈人昵称 | FeederName | nvarchar(max) |
4 | 反馈连接 | FeedConnect | Datetime2 |
5 6 7 | 主题 内容 反馈时间 | Titl Contente FeedTime | Datetime2 Datetime2 Datetime2 |
5系统实现
5.1用户模块
本项目中的用户模块主要包含的功能有用户的注册、登录、信息查看与管理等。用户在进入平台时,平台会判断用户的登录状态。用户如果没有登录,会引导用户进入登录界面进行登录。如果用户登录时,后端发现其账号还未注册,平台会引导用户进行账号的注册,注册后用户便可进行登录并进入平台进行相关功能的使用。使用 ASP.NET Core Identity 框架来实现用户模块。
5.1.1用户登录与注册的设计与实现
使用 ASP.NET Core Identity 提供的 UserManager 服务创建新用户,然后使用其提供的SignInManager 服务来登录用户。UserManager <IdentityUser>类包含管理基础数据存储中的用户所需的方法。比如,此类具有 CreateAsync()、DeleteAsync()和 UpdateAsync()等方法来创建、删除和更新用户。
SignInManager <IdentityUser>类包含用户登录所需的方法。比如,SignInManager 类具有 SignInAsync()、SignOutAsync()等方法来登录和注销用户。注册界面如图 51所示。
5.1.2用户信息查看
用户在登录成功后,进入到主界面,由于已经登录,用户可以访问那些权限为登录权限的方法。例如,用户在平台中的我的界面中可以查看自己的信息并进行管理,如图 52、图 53所示。
5.2论坛模块实现
本项目中的论坛模块主要包含的功能有在论坛上的发帖,回帖等功能。
5.2.1发帖
用户在未登录之前可以看到论坛上的贴子,但不可以发布自己的帖子,只有登录后才可以发帖如所示。
选择话题热点/新创一个话题热点后便可以发布自己的帖子。帖子可以使富媒体内容,可以放入文件,图片,视频等,还可以对文本进行样式处理,如图 54所示。
5.2.2帖子评论
在论坛主页面,帖子在发布之后用户看到之后可以进行回帖,如图 55所示。
可以多重评论,展收评论,如图 56所示。
5.2.3点赞收藏与转发
用户可以给帖子点赞,收藏帖子,转发帖子。收藏的帖子会在用户主页显示,转发的帖子会出现在动态当中,如图 57所示。
5.3朋友圈子模块
该模块只要实现对用户之间进行交互的功能,用户与用户之间可以进行互相关注,留言,可以看到别人的动态等等,关注用户之后还可在个人主页看到自己关注的用户。
5.3.1动态
用户可以发表动态,动态出现在动态页中,只有关注自己的用户才能看到自己的动态。同时,自己的动态也会出现在个人主页中,方便管理,如图 58所示。
5.3.2关注和留言
关注、留言是在论坛之外提供朋友交互的功能,它们拉近了用户间的距离。关注和留言界面如图 59,图 510所示。
5.4信息聚合模块
信息聚合模块爬取了临沂大学网站的临大新闻以及信息科学与工程学院的新闻,将其展示在系统中。通过信息聚合,使得同学们不用在多个网站之间切换来寻找信息。信息聚合模块分为概览页和列表页。概览页显示了各个板块最近一条新闻的标题和时间,列表页按时间顺序显示了模块的新闻列表。概览页和列表页分别如图 511,图 512所示。
5.5管理模块
管理模块提供了对帖子,评论,话题,用户,反馈等的管理。总览与话题管理界面如图 513,图 514所示。
5.6其它
其它功能主要有帖子搜索,未读消息,反馈以及响应式设计。
5.6.1未读消息
在用户的帖子有新评论、新关注、新留言时,用户会在未读栏收到提醒,通过链接更快速的查看,如图 515所示。
5.6.2响应式设计
现在同学们主要使用移动设备上网,这个对移动端进行了优化,如图 516所示。
6系统测试
6.1测试目的
系统测试环节对于确保系统功能完善且稳定性关键至关重要,其繁琐而大量的测试步骤旨在验证系统功能的有效性和稳定性,唯有系统功能稳定,方可保障用户使用体验。因此,在系统投入使用前,系统测试阶段显得异常重要,我将在其中选取几项用户常用功能进行深入测试。
6.2测试系统环境
硬件环境如下表 61所示。
名称 | 配置 |
Cpu | AMD R7 |
内存 | 16GB |
设备型号 | G3 3579 |
浏览器 | 谷歌浏览器 |
软件环境如下表 62所示。
名称 | 配置 |
操作系统 | Windows 11 |
Web服务器 | IIS |
数据库 | MySQL |
开发环境 | VS |
6.3功能测试
6.3.1系统登录功能测试
测试流程:
-
- 分别转入管理员、用户登录界面,重复输入对应的不正确的登录信息
- 登录
- 分别输入正确和错误的登录账号和登录密码
- 登录
测试结果下如表 63所示。
测试功能 | 试用用例 | 目标结果 | 实际结果 | 是否通过测试 |
管理员登录 | 用户名guanliyuan 密码:123456 | 登录成功 | 登录成功 | 通过测试 |
管理员登录 | 用户名:t_1 密码:123456 | 系统提示:当前用户不是管理员 | 系统提示:当前用户不是管理员 | 通过测试 |
管理员登录 | 用户名:123 密码:123 | 登陆失败 | 登录失败 | 通过测试 |
用户登录 | 用户名:1705990335 密码:123456 | 登录成功 | 登录成功 | 通过测试 |
用户登录 | 用户名:t_1 密码:123456 | 系统提示:当前用户不是学生 | 系统提示:当前用户不是学生 | 通过测试 |
用户登录 | 用户名:123 密码:123 | 登录失败 | 登录失败 | 通过测试 |
6.3.2用户发帖功能测试
测试流程:
- 用户登录
- 用户发帖
测试结果下如表 64所示。
测试功能 | 试用用例 | 目标结果 | 实际结果 | 是否通过 |
用户发帖 | 帖子1 | 成功,显示主界面 | 成功,显示主界面 | 通过 |
用户发帖 | 帖子2 | 成功,显示主界面 | 成功,显示主界面 | 通过 |
6.3.3资讯聚合测试
在该模块中对Python项目进行测试,测试爬取信息的准确性全面性,信息获取的时效性,快速性,测试结果如下表 65所示。
模块名称 | 用例 | 计划结果 | 实际结果 | 是否通过 |
资讯聚合 | 网站1,学生账户1 | 审核通过 | 审核通过 | 通过 |
资讯聚合 | 网站2,学生账户2 | 审核通过 | 审核未通过 | 通过 |
资讯聚合 | 网站3,学生账户3 | 审核通过 | 审核未通过 | 通过 |
资讯聚合 | 网站4,学生账户2 | 审核通过 | 审核未通过 | 通过 |
资讯聚合 | 网站5,学生账户2 | 审核未通过 | 审核未通过 | 通过 |
7总结
本文为提高学生信息获取和交流的便捷性、高效性,基于ASP.NET Core,利用 Bootstrap,EF Core,MySQL等技术,设计并实现本系统项目。为保证系统实际应用价值,本项目设计与实现过程中也进行了多次的功能改造和界面优化。
在此对开发工作进行了简要总结,具体内容如下:
本项目使用了ASP.NET Core框架,MVC开发模式,通过引入各种第三方插件提供的解决方案,满足了开发过程中的各种需求,开发成本低,开发效率高。数据库选择了MySQL 数据库,为今后可能的海量数据存取提供了基础的性能保障。并且结构丰富,支持灵活快速的存取结构,为本项目的开发提供了充足的便利性。
本次开发利用以上技术设计并实现了系统系统,实现了用户与管理者的权限全部基础流程。但是项目中还存在许多缺陷与不足,仍需改进和完善。
-
- 梁桐铭. 深入浅出ASP.NET Core[M]. 北京:人民邮电出版社, 2020.
- Adam Freeman. 精通ASP.NET Core MVC(第7版)[M]. 北京:人民邮电出版社, 2021.
- Joseph Albahari. C# 8.0核心技术指南.[M]. 北京:机械工业出版社, 2021.
- 黑马程序员. JavaScript + jQuery 交互式Web 前端开发[M]. 北京:人民邮电出版社, 2020.
- 罗福强等. C#程序设计经典教程(第三版)[M]. 北京:清华大学出版社, 2018.
- 丹尼尔·索利斯. C#图解教程(中译本第五版)[M]. 北京: 人民邮电出版社, 2019.
- 王志亮,纪松波. 基于SpringBoot的Web前端与数据库的接口设计 [J]. 工业控制计算机, 2023, 36 (03): 51-53.
- 赵志威,张生月,蒋应举等. 基于SpringBoot的高新技术企业创新能力评价平台设计与实现 [J]. 现代信息科技, 2021, 5 (15): 40-42.
- 宋馨来,张海涛. 基于前后端分离和Spring Security的用户登录功能的设计与实现 [J]. 科技创新与应用, 2021, 11 (18): 19-21+24.
- 谭浩强. C语言程序设计(第2版)[M]. 北京:清华大学出版社, 2010.
- 王珊, 萨师煊. 数据库系统概论(第4版)[M]. 北京:高等教育出版社, 2006.
- 肖航,王威.校园信息交流和资源共享平台的设计与实现[J].科学技术创新,2023(21):76-77.
- 王瑶琪,聂建峰,张芳.加快智慧校园建设 推进大学治理现代化[J].中国高等教育,2021.
- Paulo Novais et al. Social and intelligent applications for future cities: Current advances[J] Future Generation Computer Systems, 2021, 114.
- Sopachitwatana S, Yamada K, Wang Y, et al. Study of Multidimensional Design Approaches to Emergency Signage[J]. International Journal of Asia Digital Art and Design Association, 2021, 25(3): 39-48.
- 周羿.基于 iOS 的校园交易信息平台客户端的设计与实现[D].湖南大学,2013.
- Hollie Gardner. A User-Centric Approach to Wayfinding Signage[J]. Public Services Quarterly,2022,14(4).
- 贾钰峰,王博.浅谈校园信息共享平台的构建[J].计算机产品与流通,2020(08):89.
- 林佳一.混合式教学在高职MySQL数据库课程的实践研究[J].电脑知识与技术,2022,18(26):133-135.
[20] 杨雨成,任利峰.MySQL数据库性能优化技术研究[J].科技经济导刊,2020,28(03):32.
致谢是论文的终篇,但不是青春的终点。
随着时间的流逝,美好的大学时光即将迎来完美的结局。回首过往,留下的皆是美好回忆。即将怀揣着期许和祝福,离开校园,踏上新的征程。 深谋远虑,潜心治学,追溯学问源起;肄业向导,赖以成长,感激孟老师的悉心教导。孟老师学识渊博,治学态度严谨,繁忙之际仍抽空指导我,赐予宝贵建议。师恩难忘,知音难觅;在潜移默化之中,感受着老师的教诲与影响。愿您与家人幸福安康,万事如意!父母对子女的爱,常伴随着深远的谋划。在此感谢父母二十余年来无微不至的关怀和支持,给予了我无穷无尽的关爱和温暖,让我得以立足于他们的肩膀之上,洞悉更为广阔的世界。对于父母的养育之恩,我无法用任何方式加以回报,唯有不断努力,成为他们引以为豪的女儿。愿父母身体健康,平安幸福! 山水阔别,多年有幸。感激一直陪伴在我身边的朋友们,有这么多可爱的人陪着我,为我提出宝贵的意见和建议,有了他们的鼓励和支持,我才充实地度过了美好的大学生涯,也让我的大学生活充满了温暖与欢乐。即将毕业,顺祝同学们前程似锦! 当论文即将尾声时,回首所有经历,对所遇见之人事怀感恩之情,展望未来,尽管或许途中孤寂漫长,然仍怀望经过努力后,未来必将晴空万里。 风亦有兴衰,人亦有相聚与离别之情,唯有脚踏实地生活,方能不负所遇之情。坚信一切皆为最佳安排,尽管大学岁月渐行渐远,却也意味着我们的人生之旅才刚刚起航!去读书,去识人,去看时间美好的风景,前途漫漫亦灿灿,慢慢来吧,慢慢相遇。 往事暗沉不可追,来日之路光明灿烂!最后我要感谢始终真诚、始终热烈、始终勇敢的自己,希望我在充满无限可能的未来里,知不足而奋进,望远山而前行!
董济楠
2024年4月18日
标签:Core,聚合,登录,圈子,用户,信息,校园论坛,NET,数据库 From: https://blog.csdn.net/qq_43343291/article/details/139707901