NodeJS小说网站-毕业设计源码67309

目  录

摘要

1 绪论

1.1 研究背景

1.2 研究意义

1.3论文结构与章节安排

2 相关技术介绍

2.1 B/S结构

2.2 Node.js主要功能

2.3 MySQL数据库

3系统分析

3.1 可行性分析

3.2 系统流程分析

3.2.1 数据新增流程

3.2.2 数据修改流程

3.2.2 数据删除流程

3.3 系统功能分析

3.3.1 功能性分析

3.3.2 非功能性分析

3.4 系统用例分析

3.5本章小结

4 系统总体设计

4.1 系统架构设计

4.2 系统功能模块设计

4.3 数据库设计

4.3.1 数据库概念结构设计

4.3.2 数据库逻辑结构设计

表access_token (登陆访问时长)

表article (文章:用于内容管理系统的文章)

表article_type (文章分类)

表auth (用户权限管理)

表author_user (作者用户)

表collect (收藏)

表comment (评论)

表hits (用户点击)

表link (友情链接)

表notice (公告)

表novel_chapters (小说章节)

表novel_classification (小说分类)

表novel_genre (小说类型)

表novel_information (小说信息)

表praise (点赞)

表regular_users (普通用户)

表sensitive_vocabulary (敏感词汇)

表slides (轮播图)

表upload (文件上传)

表user (用户账户:用于保存用户登录信息)

表user_group (用户组:用于用户前端身份和鉴权)

4.4本章小结

5 系统详细设计与实现

5.1注册登录功能模块

5.1.1 用户注册界面

5.1.2 用户登录界面

5.2作者用户功能模块

5.2.1 前台首页界面

5.2.2 小说资讯界面

5.2.3 小说信息界面

5.2.4个人中心界面

5.3普通用户功能模块

5.3.1 我的账户界面

5.3.2 通知公告界面

5.3.3 小说信息界面

5.3.4个人中心界面

5.4管理员功能模块

5.4.1 系统用户界面

5.4.2小说分类管理界面

5.4.3小说类型管理界面

5.4.4小说信息管理界面

5.4.5发布小说管理界面

5.4.6系统管理界面

5.4.7资源管理界面

6系统测试

6.1 系统测试目的

6.2系统测试用例

6.3 系统测试结果

7 结论

参考文献

致  谢

摘要

随着互联网技术的快速发展,网络文学已成为人们生活中不可或缺的一部分。其中,小说作为最受欢迎的文学形式之一,其网站开发技术也备受关注。本文提出的小说网站是基于node.js语言、MySQL数据库和Node.js框架为技术基础进行设计开发的。Node.js具有出色的性能。它采用事件驱动、非阻塞I/O模型,使得其在处理高并发、I/O密集型任务时具有很高的效率。这对于小说网站来说,意味着可以同时处理大量的用户请求,提供流畅的阅读体验。

本文首先介绍了系统的研究背景、意义和相关技术;然后对系统进行了可行性、功能性等分析;接着详细介绍了系统的设计原理和实现细节,包括数据库设计、系统架构、主要功能模块等;最后对系统进行了部署和测试。通过本系统的的成功实施,不仅为网络文学的发展提供了新的可能性,也为其他类似系统的设计和实现提供了有益的参考。

关键词:网络文学;小说网站;Node.js

Abstract

With the rapid development of Internet technology, online literature has become an indispensable part of people's life. Among them, novels, as one of the most popular literary forms, have also received much attention in terms of website development technology. The novel website proposed in this article is designed and developed based on the Node.js language, MySQL database, and Node.js framework. Node.js has excellent performance. It adopts an event driven, non blocking I/O model, which makes it highly efficient in handling high concurrency and I/O intensive tasks. For novel websites, this means that they can simultaneously handle a large number of user requests and provide a smooth reading experience.

This article first introduces the research background, significance, and related technologies 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 database design, system architecture, main functional modules, etc; Finally, the system was deployed and tested. The successful implementation of this system not only provides new possibilities for the development of online literature, but also provides useful references for the design and implementation of other similar systems.

Keywords: Online literature; Novel websites; Node.js

1 绪论

1.1 研究背景

随着互联网的发展,网络小说逐渐成为人们休闲娱乐的重要方式之一。然而,目前市场上的小说网站存在很多问题,如页面加载速度慢、用户体验差、内容质量不高等。这些问题严重影响了用户对小说网站的信任度和使用体验,因此,如何解决这些问题成为了一个迫切需要解决的问题。Node.js作为一种高性能的服务器端JavaScript运行环境,具有异步、非阻塞的IO模型和事件驱动的架构,能够提供高并发、高吞吐量的服务能力,可以有效解决小说网站面临的问题。

1.2 研究意义

小说作为一种重要的文化载体,具有丰富的社会价值,小说网站将有助于推动文化的发展和传播,提升社会的文化水平和精神文明。因此开发设计一个小说网站具有重要的意义。

首先,可以满足市场需求:随着互联网的普及,网络小说逐渐成为人们休闲娱乐的重要方式之一。小说网站的研究能够满足市场需求,提供更好的阅读体验和服务。

其次,可以推动行业发展:通过对小说网站的研究,可以深入了解行业的发展趋势和市场需求,为小说行业的创新和发展提供有益的参考和借鉴,从而推动整个行业的健康和持续发展。

再次,可以提升用户体验:通过研究和分析用户的需求和行为,可以优化网站的设计和功能,提高用户体验,增加用户粘性和忠诚度。

最后,有助于推动文化传播:小说作为一种重要的文化载体,具有丰富的文化内涵和价值。小说网站的研究有助于推动文化的传播和发展,提升社会的文化水平和精神文明。

1.3论文结构与章节安排

论文将分层次进行编排,除去论文摘要致谢文献参考部分,正文部分主要结构如下:

第一章:绪论,主要介绍系统的研究背景和意义,同时进行了论文整体框架的结构的简要介绍。

第二章:相关技术介绍,主要对系统开发所采用的相关技术进行介绍。

第三章:系统分析,主要对系统进行可行性技术、系统功能分析、用例分析。

第四章:系统总体设计,主要是对系统的架构、功能结构、系统数据库进行分析。

第五章:系统详细设计与实现,主要对系统的部分功能界面进行展示。

第六章:系统测试,主要对系统的主要功能进行测试。

第七章:结论,主要对系统的开发设计工作进行总结。

2 相关技术介绍

2.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体系结构使得任何时间、任何地点都能访问到该系统。

图2-1 B/S模式三层结构图

2.2 Node.js主要功能

V8引擎本身使用了一些最新的编译技术。这使得用Javascript这类脚本语言编写出来的代码运行速度获得了极大提升,又节省了开发成本。对性能的苛求是Node的一个关键因素。 Javascript是一个事件驱动语言,Node利用了这个优点,编写出可扩展性高的服务器。Node采用了一个称为“事件循环(event loop)”的架构,使得编写可扩展性高的服务器变得既容易又安全。提高服务器性能的技巧有多种多样。Node选择了一种既能提高性能,又能减低开发复杂度的架构。这是一个非常重要的特性。并发编程通常很复杂且布满地雷。Node绕过了这些,但仍提供很好的性能。

Node采用一系列“非阻塞”库来支持事件循环的方式。本质上就是为文件系统、数据库之类的资源提供接口。向文件系统发送一个请求时,无需等待硬盘(寻址并检索文件),硬盘准备好的时候非阻塞接口会通知Node。该模型以可扩展的方式简化了对慢资源的访问, 直观,易懂。尤其是对于熟悉onmouseover、onclick等DOM事件的用户,更有一种似曾相识的感觉。

虽然让Javascript运行于服务器端不是Node的独特之处,但却是其一强大功能。不得不承认,浏览器环境限制了我们选择编程语言的自由。任何服务器与日益复杂的浏览器客户端应用程序间共享代码的愿望只能通过Javascript来实现。虽然还存在其他一些支持Javascript在服务器端 运行的平台,但因为上述特性,Node发展迅猛,成为事实上的平台。

2.3 MySQL数据库

MySQL 经过多次的更新,功能层面已经非常的丰富和完善了,从MySQL4版本到5版本进行了比较大的更新,在商业的实际使用中取得了很好的实际应用效果。最新版本的MySQL支持对信息的压缩,同时还能进行加密能更好的满足对信息安全性的需求。同时经过系统的多次更新,数据库自身的镜像功能也得到了很大的增强,运行的流畅度和易用性方面有了不小的进步,驱动的使用和创建也更加的高效快捷。最大的变动还是进行了空间信息的显示优化,能更加方便的在应用地图上进行坐标的标注和运算。强大的备份功能也保证了用户使用的过程会更加安心,同时支持的Office特性还支持用户的自行安装和使用。在信息的显示形式上也进行了不小的更新,增加了两个非常使用的显示区,一个是信息区,对表格和文字进行了分类处理,界面的显示更加清爽和具体。第二是仪表的信息控件,能在仪表信息区进行信息的显示,同时还能进行多个信息的比对,为用户的实际使用带来了很大的便捷

3系统分析

系统分析是开发一个项目的先决条件,通过系统分析可以很好的了解系统的主体用户的基本需求情况,同时这也是项目的开发的原因。进而对系统开发进行可行性分析,通常包括技术可行性、经济可行性等,可行性分析同时也是从项目整体角度进行的分析。然后就是对项目的具体需求进行分析,分析的手段一般都是通过用户的用例图来实现。下面是详细的介绍。

3.1 可行性分析

(1)技术可行性:

随着Node.js的普及和应用,越来越多的企业和开发者开始使用Node.js构建网站和应用。Node.js作为一种高性能的服务器端JavaScript运行环境,具有异步、非阻塞的IO模型和事件驱动的架构,能够提供高并发、高吞吐量的服务能力,可以有效解决小说网站面临的问题。因此,从技术角度分析是可行的。

(2)经济可行性:

Node.js它有着庞大的社区支持和大量的第三方库,可以帮助开发者快速地实现各种功能。这对于小说网站来说,意味着以较低的成本,实现高质量。因此,从经济角度分析是可行的。

  1. 市场可行性:

小说作为文学的一个重要分支,一直拥有庞大的受众群体。随着移动互联网的普及,越来越多的用户选择在线阅读小说,小说网站具有很大的市场发展空间。因此,从市场角度分析是可行的。

3.2 系统流程分析

系统流程是用一些特定的符合和线条来进行演示用户在使用系统时的过程,在进行系统分析的时候,业务流程可以帮助开发人员更好的理解业务,发现错误,完善系统。

3.2.1 数据新增流程

用户成功登入系统后能够实现增加数据的操作,增加数据的编号系统生成,用户不能随意填写,除了编号以外,其他增加信息用户自己填写,填写后的信息经过系统验证,验证通过后即可完成数据新增数据新增的流程图如下图3-1所示

图3-1  数据新增流程图

3.2.2 数据修改流程

数据修改时的流程和上面介绍的数据增加时的流程相似如下图3-2所示

图3-2  数据修改流程图

3.2.2 数据删除流程

如果系统里面存在一些没有用的数据,相关的管理人员还可以对这些数据进行删除,数据删除时流程图如下图3-3所示

图3-3  数据删除流程图

3.3 系统功能分析

3.3.1 功能性分析

按照小说网站的角色,主要包括作者用户、普通用户和管理员这三大功能模块,各模块主要功能内容如下:

  1. 作者用户功能:
  1. 首页:用户可以查看首页展示的轮播图、通知公告、小说资讯等相关内容。
  2. 注册登录:用户可以通过注册成为系统用户,注册后可以用账号密码登录系统。
  3. 通知公告:用户可以查看网站发布的通知公告信息。
  4. 小说资讯:用户可以查看小说资讯列表中的某一资讯详情并可以进行点赞、收藏和发表评论操作。
  5. 小说信息:户可以查看小说信息列表中某一小说信息详情并可以进行点赞、收藏和发表评论操作。
  6. 我的:用户可以修改个人资料,可以查看和管理个人中心中的个人首页、发布小说和收藏信息。
  1. 普通用户功能:
  1. 首页:用户可以查看首页展示的轮播图、通知公告、小说资讯等相关内容。
  2. 注册登录:用户可以通过注册成为系统用户,注册后可以用账号密码登录系统。
  3. 通知公告:用户可以查看网站发布的通知公告信息。
  4. 小说资讯:用户可以查看小说资讯列表中的某一资讯详情并可以进行点赞、收藏和发表评论操作。
  5. 小说信息:户可以查看小说信息列表中某一小说信息详情并可以进行点赞、收藏和发表评论操作。
  6. 我的:用户可以修改个人资料,可以查看和管理个人中心中的个人首页和收藏信息。
  1. 管理员功能:
  1. 后台首页:管理员可以查看后台首页展示的相关信息。
  2. 系统用户:管理员可以对系统用户信息进行进行查询、添加、重置和删除操作。
  3. 小说分类管理:管理员可以对小说分类信息进行查询、添加、重置和删除操作。
  4. 小说类型管理:管理员可以对小说类型信息进行查询、添加、重置和删除操作。
  5. 小说信息管理:管理员可以对小说信息进行查询、重置和删除操作。
  6. 发布小说管理:管理员可以对发布小说信息进行查询、添加、重置和删除操作。
  7. 系统管理:管理员可以对友情链接、轮播图管理、敏感词管理信息进行查询、添加、重置和删除操作。
  8. 通知公告管理:管理员可以对通知公告信息进行查询、添加、重置和删除操作。
  9. 资源管理:管理员可以对小说资讯、资讯分类信息进行查询、添加、重置和删除操作。

3.3.2 非功能性分析

小说网站的非功能性需求比如小说网站的安全性怎么样,可靠性怎么样,性能怎么样,可拓展性怎么样等。具体可以表示在如下3-1表格中:

3-1小说网站非功能需求表

安全性

主要指小说网站数据库的安装,数据库的使用和密码的设定必须合乎规范。

可靠性

可靠性是指小说网站能够安装用户的指示进行操作,经过测试,可靠性90%以上。

性能

性能是影响小说网站占据市场的必要条件,所以性能最好要佳才好。

可扩展性

比如数据库预留多个属性,比如接口的使用等确保了系统的非功能性需求。

易用性

用户只要跟着小说网站的页面展示内容进行操作,就可以了。

可维护性

小说网站开发的可维护性是非常重要的,经过测试,可维护性没有问题

3.4 系统用例分析

通过3.3功能的分析,得出了本小说网站的用户角色用例图:

作者用户角色用例图如下图3-4所示:

图3-4 作者用户角色用例图

普通用户角色用例图如下图3-5所示:

图3-5 普通用户角色用例图

管理员角色用例图如下图3-6所示:

图3-6 管理员角色用例图

3.5本章小结

本章主要通过对小说网站的可行性分析、流程分析、功能需求分析、系统用例分析,确定整个小说网站要实现的功能。同时也为小说网站的代码实现和测试提供了标准。

4 系统总体设计

本章主要讨论的内容包括小说网站的架构设计、功能模块设计、数据库系统设计。

4.1 系统架构设计

本小说网站从架构上分为三层:表现层(UI)、业务逻辑层(BLL)以及数据层(DL)。

图4-1小说网站系统架构设计图

表现层(UI):又称UI层,主要完成本小说网站的UI交互功能,一个良好的UI可以打打提高用户的用户体验,增强用户使用本小说网站时的舒适度。UI的界面设计也要适应不同版本的小说网站以及不同尺寸的分辨率,以做到良好的兼容性。UI交互功能要求合理,用户进行交互操作时必须要得到与之相符的交互结果,这就要求表现层要与业务逻辑层进行良好的对接。

业务逻辑层(BLL):主要完成本小说网站的数据处理功能。用户从表现层传输过来的数据经过业务逻辑层进行处理交付给数据层,系统从数据层读取的数据经过业务逻辑层进行处理交付给表现层。

数据层(DL):由于本小说网站的数据是放在服务端的MySQL数据库中,因此本属于服务层的部分可以直接整合在业务逻辑层中,所以数据层中只有数据库,其主要完成本小说网站的数据存储和管理功能。

4.2 系统功能模块设计

在上一章节中主要对系统的功能性需求和非功能性需求进行分析,并且根据需求分析了本小说网站中的角色用例。那么接下来就要开始对本小说网站的架构、主要功能和数据库开始进行设计。小说网站根据前面章节的需求分析得出,其总体设计模块图如图4-2所示。

图4-2 系统功能模块图

4.3 数据库设计

数据库设计一般包括需求分析、概念模型设计、数据库表建立三大过程,其中需求分析前面章节已经阐述,概念模型设计有概念模型和逻辑结构设计两部分。

4.3.1 数据库概念结构设计

下面是整个小说网站中主要的数据库表总E-R实体关系图。

图4-3 系统总E-R关系图

4.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

用户编号:

表article (文章:用于内容管理系统的文章)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

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

文章描述

表article_type (文章分类)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

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

更新时间:

表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

更新时间:

表author_user (作者用户)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

author_user_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

更新时间

表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:

表link (友情链接)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

link_id

smallint

5

0

N

Y

友情链接ID:[0,32767]

2

display

smallint

5

0

N

N

100

显示顺序:[0,10000]数值越小,越优先显示

3

name

varchar

32

0

Y

N

链接名称:[0,32]

4

img

varchar

255

0

Y

N

友情链接图:[0,255]

5

url

varchar

255

0

Y

N

跳转链接:[0,255]

6

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

7

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

更新时间:

表novel_chapters (小说章节)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

novel_chapters_id

int

10

0

N

Y

小说章节ID

2

chapter_name

varchar

64

0

Y

N

章节名称

3

sort

int

10

0

Y

N

0

排序

4

chapter_content

longtext

2147483647

0

Y

N

章节内容

5

novel_reading_id

int

10

0

Y

N

小说id

6

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

7

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表novel_classification (小说分类)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

novel_classification_id

int

10

0

N

Y

小说分类ID

2

novel_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

更新时间

表novel_genre (小说类型)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

novel_genre_id

int

10

0

N

Y

小说类型ID

2

novel_genre

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

更新时间

表novel_information (小说信息)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

novel_information_id

int

10

0

N

Y

小说信息ID

2

author_user

int

10

0

Y

N

0

作者用户

3

user_name

varchar

64

0

Y

N

用户姓名

4

title_of_the_novel

varchar

64

0

Y

N

小说名称

5

novel_cover

varchar

255

0

Y

N

小说封面

6

novel_classification

varchar

64

0

Y

N

小说分类

7

novel_genre

varchar

64

0

Y

N

小说类型

8

introduction_to_the_novel

text

65535

0

Y

N

小说简介

9

hits

int

10

0

N

N

0

点击数

10

praise_len

int

10

0

N

N

0

点赞数

11

examine_state

varchar

16

0

N

N

未审核

审核状态

12

examine_reply

varchar

16

0

Y

N

审核回复

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

更新时间

表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已取消

表regular_users (普通用户)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

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

birthday_information

date

10

0

Y

N

生日信息

6

examine_state

varchar

16

0

N

N

已通过

审核状态

7

user_id

int

10

0

N

N

0

用户ID

8

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

9

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表sensitive_vocabulary (敏感词汇)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

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

更新时间

表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

创建时间:

表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

更新时间:

4.4本章小结

整个小说网站的需求分析主要对系统总体架构以及功能模块的设计,通过建立E-R模型和数据库逻辑系统设计完成了数据库系统设计。

5 系统详细设计与实现

小说网站的详细设计与实现主要是根据前面的小说网站的需求分析和小说网站的总体设计来设计页面并实现业务逻辑。主要从小说网站界面实现、业务逻辑实现这两部分进行介绍。

5.1注册登录功能模块

5.1.1 用户注册界面

用户右上角“注册”按钮进入注册页面填写账号、密码、确认密码、昵称、邮箱、身份等信息后点击“注册”按钮,系统会对输入的信息进行验证,验证通过后即可完成注册,其界面展示如下图5-1所示。

图5-1 用户注册界面图

用户注册的关键代码如下:

Register.prototype.index = async function(ctx) {

var group_list = await $.services["user_group"].get_list({}, Object.assign({}, this.config));

return await ctx.render(this.config.tpl + "index.html", {

group_list

});

};

Register.prototype.api = async function(ctx) {

var user = $.services.user;

var body = ctx.request.body;

var username = body.username;

var obj = await user.get_obj({

username

});

if (obj) {

return {

error: {

code: 70000,

message: "账户名已存在",

},

};

} else {

var password = md5(body.password);

var nickname = body.nickname;

var user_group = body.user_group;

var email = body.email;

var email_state= body.hasOwnProperty('email_state') ? body.email_state : 0;

var phone = body.phone;

var phone_state= body.hasOwnProperty('phone_state') ? body.phone_state : 0;

var avatar = body.avatar;

var bl_reg = await user.add({

username,

password,

nickname,

user_group,

email,

email_state,

phone,

phone_state,

avatar

});

if (bl_reg) {

return {

result: "注册成功"

};

} else {

return {

error: {

code: 70000,

message: "注册失败",

},

};

}

}

};

5.1.2 用户登录界面

用户注册后可以通过自己的账户名和密码进行登录的,当用户输入完整的自己的账户名和密码信息并点击“登录”按钮后,系统会对输入的信息进行验证,验证通过后即可完成登录,其界面如下图5-2所示。

图5-2用户登录界面图

用户登录关键代码如下:

const md5 = require("md5");

var Controller = require("../core/controller.js");

class Login extends Controller {

constructor(config) {

super(

Object.assign({

tpl: "./login/",

service: "user",

},

config

)

);

}

}

Login.prototype.api = async function(ctx) {

var body = ctx.request.body;

var obj = await $.services["user"].get_obj({

username: body.username

},{like:false});

if (obj) {

var group = await $.services["user_group"].get_obj({

name:obj.user_group

})

if (group){

if (group.name!=="管理员"){

var sql = "select examine_state from "+ group.source_table +" WHERE user_id = " + obj.user_id;

var userExamine = await $.mysql.run(sql);

if (userExamine && userExamine.length > 0 && userExamine[0].examine_state!=="已通过"){

return {

error: {

code: 70000,

message: "该用户审核未通过"

},

};

}

}

if (obj.state!==1){

return {

error: {

code: 70000,

message: "用户非可用状态,不能登录"

},

};

}

var password = md5(body.password);

if (password === obj.password) {

ctx.session.user = obj;

var date = Date.parse(new Date());

var token = md5(obj.user_id + "_" + date);

await $.services["access_token"].add({

token,

info: JSON.stringify(obj),

user_id:obj.user_id

});

obj.token = token;

return {

result: {obj}

};

} else {

return {

error: {

code: 70000,

message: "密码错误"

},

};

}

}else {

return {

error: {

code: 70000,

message: "用户组不存在"

},

};

}

} else {

return {

error: {

code: 70000,

message: "账户不存在"

}

};

}

};

5.2作者用户功能模块

5.2.1 前台首页界面

网站首页以上中下的布局进行展示,正上方是系统的导航栏,中间是轮播图,下面是通知公告、小说资讯、小说信息推荐等信息,其主界面展示如下图5-3所示。

图5-3 前台首页界面图

5.2.2 小说资讯界面

用户可以查看小说资讯列表中的某一资讯详情并可以进行点赞、收藏和发表评论操作,其界面展示如下图5-4所示。

图5-4 小说资讯界面图

5.2.3 小说信息界面

用户可以查看小说信息列表中某一小说信息详情并可以进行点赞、收藏和发表评论操作,同时支持通过多种搜索方式查找小说,其界面如下图5-5所示。

图5-5小说信息界面图

5.2.4个人中心界面

用户在个人中心界面可以查看个人首页和收藏信息,可以发布小说,可以对发布小说的信息进行查询、重置、添加和删除操作,其界面如下图5-6所示。

图5-6个人中心界面图

5.3普通用户功能模块

5.3.1 我的账户界面

用户可以查看和修改我的账户中的个人资料,如头像、昵称、登录密码登,其界面如下图5-7所示。

图5-7我的账户界面图

5.3.2 通知公告界面

用户可以查看通知公告列表中的某一信息详情,其界面如图5-8所示。

图5-8 通知公告界面图

5.3.3 小说信息界面

用户可以查看小说信息列表中某一小说信息详情并可以进行点赞、收藏和发表评论操作,同时支持通过多种搜索方式查找小说其界面如下图5-9所示:

图5-9 小说信息界面图

5.3.4个人中心界面

用户可以查看个人中心中的个人首页和收藏信息,可以对收藏列表信息进行删除操作,其界面如下图5-10所示:

图5-10 个人中心界面图

5.4管理员功能模块

5.4.1 系统用户界面

管理员可以系统用户列表中的某一用户详情,可以系统用户信息进行查询、重置、添加和删除操作,其界面如下图5-11所示。

图5-11系统用户界面图

信息添加的关键代码如下:

Controller.prototype.add = async function(ctx) {

var result = await this.service.add(ctx.request.body, this.config);

if (this.service.error) {

return {

error: this.service.error,

};

}

return {

result,

};

};

信息删除的关键代码如下:

Controller.prototype.del = async function(ctx) {

if (!Object.keys(ctx.query).length) {

return {

code: 30000,

message: "删除条件不能为空!",

};

}

var result = await this.service.del(ctx.request.query, this.config);

if (this.service.error) {

return {

error: this.service.error,

};

}

return {

result,

};

};

5.4.2小说分类管理界面

管理员可以查看小说分类列表中某一分类详情,可以对小说分类信息进行查询、重置、添加和删除操作,其界面如下图5-12所示。

图5-12小说分类管理界面图

5.4.3小说类型管理界面

管理员可以查看小说类型列表中某一类型信息详情,可以对小说类型信息进行查询、重置、添加和删除操作,其界面如下图5-13所示。

图5-13小说类型管理界面图

5.4.4小说信息管理界面

管理员可以小说信息列表中某一小说详情和评论信息,可以对小说信息进行查询、重置和删除操作,其界面如下图5-14所示。

图5-14小说信息管理界面图

5.4.5发布小说管理界面

管理员可以查看发布小说列表信息中的某一小说详情并进行审核和回复,对已审核的小说可以进行小说发布的提交操作,可以对发布小说信息进行查询、添加、重置和删除操作,其界面如下图5-15所示。

图5-15发布小说管理界面图

5.4.6系统管理界面

管理员可以对友情链接、轮播图管理、敏感词管理信息进行查询、添加、重置和删除操作,其界面如下图5-16所示。

图5-16系统管理界面图

文件/图片上传的关键代码如下:

Controller.prototype.upload = async function(ctx) {

var req = ctx.request;

var query = req.query;

var url = "";

if (req.files && req.files.file) {

var f = req.files.file;

const render = fs.createReadStream(f.path);

var name = f.name;

var dir = f.dir || "";

var file = _dir + dir + name;

try {

if (fs.existsSync(file)) {

var arr = name.split(".");

name = arr[0];

var extension = arr[arr.length - 1];

var num = 10000;

for (var i = 0; i < num; i++) {

var na = name + "_" + (i + 1) + "." + extension;

file = path.join(_dir, na);

if (!fs.existsSync(file)) {

name = na;

break;

}

}

}

const upStream = fs.createWriteStream(file);

render.pipe(upStream);

url = _path + name;

} catch (e) {

console.log("上传失败:", e);

}

return {

result: {

url

}

};

} else {

return {

code: 10000,

message: "上传的文件(file)不能为空!",

};

}

};

5.4.7资源管理界面

管理员可以查看小说资讯列表中某一资讯详情和评论信息,可以对小说资讯、资讯分类信息进行查询、添加、重置和删除操作,其界面如下图5-17所示。

图5-17资源管理界面图

6系统测试

6.1 系统测试目的

无论什么样的系统,测试都至关重要,通过测试可以检查出潜藏的缺陷,从而确保系统的性能和稳定性,避免Bug的出现,并确保系统的功能和性价比达到预期的要求。

6.2系统测试用例

系统测试包括:用户登录功能测试、小说资讯查看功能、轮播图信息添加功能、密码修改功能测试,如表6-1、6-2、6-3、6-4所示:

用户登录功能测试:

表6-1 用户登录功能测试表

用例名称

用户登录系统

目的

测试用户通过正确的用户名和密码可否登录功能

前提

未登录的情况下

测试流程

1) 进入登录页面

2) 输入正确的用户名和密码

预期结果

用户名和密码正确的时候,跳转到登录成功界面,反之则显示错误信息,提示重新输入

实际结果

实际结果与预期结果一致

小说资讯查看功能测试:

表6-2 小说资讯查看功能测试表

用例名称

小说资讯查看

目的

测试小说资讯查看功能

前提

用户登录

测试流程

点击小说资讯

预期结果

可以查看到所有小说资讯信息

实际结果

实际结果与预期结果一致

轮播图信息添加界面测试:

表6-3 轮播图信息添加界面测试表

用例名称

轮播图信息添加测试用例

目的

测试轮播图信息添加功能

前提

管理员用户正常登录情况下

测试流程

1)管理员点击系统管理下方的轮播图管理,然后点击添加进入添加页面填写信息。

2)填写完毕后点击进行提交。

预期结果

提交以后,页面首页会显示新的轮播图信息

实际结果

实际结果与预期结果一致

密码修改功能测试:

表6-4 个密码修改功能测试表

用例名称

密码修改测试用例

目的

测试作者用户密码修改功能

前提

作者用户正常登录情况下

测试流程

1)作者用户点击右上角“我的”下方按扭“我的账户”进入页面点击密码修改,

2)完成修改后点击提交。

预期结果

使用新的密码可以登录

实际结果

实际结果与预期结果一致

6.3 系统测试结果

通过编写小说网站的测试用例,已经检测完毕用户登录功能测试、小说资讯查看功能、轮播图信息添加功能、密码修改功能测试,通过这四大模块的测试为小说网站的后期推广运营提供了强力的技术支撑。

7 结论

在小说网站开发之前,需要先对用户的具体需求进行分析。包括系统的可行性分析、功能需求分析以及其他需求等。在可行性分析过程中,对系统实现的技术性、经济性等方面进行了分析。总体上证明了小说网站实施的可行性。

本文总结了小说网站开发背景与意义,然后阐述了系统的具体业务需求,并根据系统需求对系统结构以及功能模块等进行了详细地设计,将整个系统划分为多个不同的功能模块。在分析系统功能需求时,对整个系统的总体架构以及功能模块等进行了分析,并选择合适的系统开发技术完成了对各个模块的开发工作。系统开发完成之后进行了部署和测试,通过测试证明了小说网站在功能以及性能等方面都达到了预期的要求,具有较高的稳定性与可靠性。

参考文献

[1]胡娟,蒲源.基于Node.js的低代码人脸识别系统的设计与实现[J].电脑知识与技术,2023,19(28):14-17.

[2]欧倍铭.网页设计中的布局与配色技巧的研究[J].电子元器件与信息技术,2023,7(08):211-213+217.

[3]叶伊,许新华,陈苏娜等.基于Web的企业影视网站设计与开发[J].电脑编程技巧与维护,2023,(08):142-144.

[4]张琳静.基于HTML5技术的跨平台网站设计与实现[J].信息记录材料,2023,24(06):131-133.

[5]刘书梅,朱红旗.浅谈网站设计的风格、色彩与排版[C]//中国国际科技促进会国际院士联合体工作委员会.2023年文化艺术创新国际学术论坛论文集(三).德州日报社;,2023:3.

[6]余琳睆.基于web的网站设计[J].信息记录材料,2023,24(02):137-139+143.

[7]万梦涵.基于4I理论的免费阅读小说平台营销策略分析[J].新媒体研究,2022,8(14):55-57.

[8]李羊羊.免费网络文学阅读平台内容生产模式研究[D].兰州财经大学,2022.

[9]窦井苒.面向互联网敏感内容检测方法的研究[D].西安电子科技大学,2022.

[10]安美芳.一种面向大数据安全的敏感内容识别机制研究与实现[D].北京交通大学,2022.

[11]唐宇.网络文学免费阅读平台及其用户增长策略研究[D].暨南大学,2022.

[12]周公平.网站制作的Web前端开发设计相关研究[J].信息记录材料,2022,23(05):183-185.

[13]王凯琪,兰全祥.网络小说信息爬取与管理系统的设计与实现[J].信息记录材料,2022,23(05):116-119.

[14]韩迎红.基于网站制作的Web前端开发技术与优化[J].软件,2022,43(04):73-75.

[15]张术梅.MVC架构下网站的设计与实现思考[J].信息记录材料,2022,23(01):92-94.

[16]马睿,王振,梁栋茂等.基于SSH框架的小说网站管理系统设计与实现[J].电脑编程技巧与维护,2020,(07):75-76+98.

[17]Wilson R .A novel siteCarmen Covito writing literature and technology[J].Italian Studies in Southern Africa/Studi d'Italianistica nell'Africa Australe,2003,16

[18]Tyson M .Intro to Hapi: The Node.js framework[J].InfoWorld.com,2023,

[19]Heller M .What is Node.js? The JavaScript runtime explained[J].InfoWorld.com,2022,

[20]  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.  

致  谢

首先,我要感谢我的论文指导老师。在论文完成的整个过程中,指导老师始终给予我无微不至的关爱与指导。在论文写作的过程中,导师那耐心细致的指导,以及提出的具有建设性的意见,都给予了我极大的帮助,让我受益匪浅。导师严谨的治学态度、敬业精神以及高水平的教学能力,都给我树立了追求卓越的典范,这对我以后的人生道路和学业成就都产生了极大的积极影响。

此外,我还要感谢我班的同学们,他们既是我的同窗好友,又是我的良师益友。正是由于你们的支持和关怀,使得我在大学期间的学习和生活都变得异常充实。感谢那些在大学期间给予我帮助的所有老师和同学们,是你们给予了我在学业道路上的前进动力。

当然,我也不能忘记我的父母,是他们用无私的爱抚养我成人。你们的养育之恩我将永生难忘,将来我一定会用我的成绩回报你们。在成长的道路上,我会不断努力,不负众望,用实际行动来回报你们对我的期望。

总之,在这篇论文中,我要感谢所有给予我帮助的人,包括指导老师、同学们、家人和朋友们。是你们的支持与关爱,让我在学术和个人生活中取得了优异的成绩。我会珍惜这份感恩之情,将这份力量用于学习和未来的生活中,不断追求卓越,成为一个更加优秀的人。

点赞+收藏+关注 →私信免费领取本源代码、数据

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值