摘要:目前,对于信息的获取是十分的重要,我们要做到的不是裹足不前,而是应该主动获取和共享给所有人。博客系统就能够实现信息获取与分享的功能,博主在发表文章后,互联网上的其他用户便可以看到,同时,博主也可以记录一些重要的信息等。在现在的软件产品的研发过程中,包含计划、分析、设计、实施和测试五个阶段,我们开发一个博客系统也是如此。一个完善的博客系统包含的功能也很多,对于不同的项目而言,侧重点可能不一样,对我们的系统而言,本系统主要实现单用户支持,实现基本的博客功能,如文章管理、评论管理、搜索等。本次系统采用Flask作为基础框架开发。主要分析了实现博客系统的相关技术。通过使用Python的Flask、Markdown、SQLAlchemy、Nginx、Redis和Mysql数据库等服务完成系统的设计与实现。本博客系统实现了游客浏览、填写相关参数后游客也可以发表评论,不过展示出来需要博主审核。博主除了可以发表文章,修改文章,删除文章等文章管理外,还可以审核用户评论、删除用户评论。本文主要对实现博客系统的相关技术,系统目标,系统的设计与实现进行介绍。
关键词:博客,Python,Flask,信息共享
Design and implementation of blog system based on Python
Abstract:At present, access to information is very important. What we should do is not to hold back, but to actively access and share it with all people. Blog system can achieve the function of information acquisition and sharing. After bloggers publish articles, other users on the Internet can see them. Meanwhile, bloggers can also record some important information. In the current software product development process, including planning, analysis, design, implementation and testing five stages, we develop a blog system is the same. A perfect blog system contains many functions. For different projects, the focus may be different. For our system, this system mainly realizes single user support and basic blog functions, such as article management, comment management, search, etc. This system uses flask as the basic framework. This paper mainly analyzes the related technologies of blog system. The system is designed and implemented by using the services of Python such as flask, markdown, Sqlalchemy, nginx, redis and MySQL database. This blog system enables visitors to browse and fill in relevant parameters, and then visitors can also comment, but it needs to be reviewed by the blogger. Bloggers can not only publish articles, modify articles, delete articles and other article management, but also review user comments and delete user comments. This paper mainly introduces the related technologies, system objectives, design and implementation of the blog system.
Keywords:blog,Python,Flask,information sharing
目 录
第1章
第1章 绪 论1
1.1个人博客研究的意义与背景1
1.1.1个人博客的发展背景1
1.1.2 本课题研究的目的与意义1
1.2 系统设计与与开发趋势2
1.2.1 系统设计思想2
1.2.2 发展趋势2
1.3 本文结构2
第2章 系统的相关技术介绍3
2.1 Flask简介3
2.2 Bootstrap简介3
2.3 MYSQL简介3
2.4 REDIS简介4
2.5 NGINX简介4
第3章 需求分析及可行性研究5
3.1 需求分析5
3.1.1系统目标5
3.1.2游客身份5
3.1.3管理员身份6
3.2可行性研究6
3.2.1 经济可行性7
3.2.2 技术的可行性7
第4章 系统总体设计8
4.1系统设计原则8
4.2系统功能设计8
4.2.1总体功能描述8
4.2.2功能模块设计9
4.2.2数据库设计10
4.3数据库设计概念10
4.3.1数据库逻辑结构设计10
4.3.2数据库物理设计11
第5章 主要功能的实现13
5.1后台登录13
5.2文章发表15
5.3用户评论17
5.4修改文章18
5.5评论审核20
5.6数据接口21
第6章 系统测试22
6.1系统测试的目的22
6.2系统测试的方法22
6.3系统测试用例22
第7章 总结与展望26
7.1博客系统的主要特点26
7.2系统的不足之处26
7.3前景展望27
参考文献:28
致谢29
第1章 绪 论
1.1个人博客研究的意义与背景
1.1.1个人博客的发展背景
在网络越发发达的现在,特别是在全球化的程序发展下,互联网已经是我们与外界交流的重要工具,而个人博客就是我们相互交流的一个重要的平台。这是互联网带给人们的变革的革命力量。互联网的发展拉近了我们与世界的距离,在给人们带来更多机会的同时,我们也要把我机会。大量甄别和获取信息。使我们不与世界脱轨。自由是个人博客的最大特征,也是博客精彩的原动力。个人博客的出现,也为人们深度交流和沟通的创造了新的网络方式。从特定的意义上来讲,它的出现和流行也是一种新的文化现象。 它的出现让人们的信息交流更加便捷,使人们工作与生活的方方面面都产生了翻天覆地的变化。
1.1.2 本课题研究的目的与意义
博客,也被称为网络日记。是一种由个人频繁更新,分享个人意见与心得、记录生活的方式。 个人博客通常是由一些简短并且经常经过更新的日志文章组成。比如可以是记忆力实在不好,所以选择记录下来。 博客的目的是在Internet上表达和发布您的各种想法,并向你展示当前的想法。随着时代的变迁和技术的发展,人们对知识的需求也越来越高,在各种网络交流方式的更迭中,博客由于自身的优越性,随着时代的发展而不断进步。博客现在在商业和个人展示等等方面都有了很大的发展。博客已经成为继论坛之后新的网络交流方式。希望博客给人们带来的更加便捷的交流平台,能使人们的生活更加便利,同时带动其他技术的发展。
1.2 系统设计与与开发趋势
1.2.1 系统设计思想
本博客系统在设计过程中,考虑到该系统一个是一个功能完备而小巧的系统,所以主要包含一下功能:发表文章、修改文章、输出文章、审核评论以及留言功能。在这些基础功能的基础上,再添加一下个性功能。如自定义链接等,本系统是针对个人的博客系统,因此它可以在上述介绍的博客系统必须具备的功能中适当精简,还应当如后面提到的,要有自己的特色。对于本系统,应做到简约展示内容。
1.2.2 发展趋势
过去几年来,随着网络的越来越发达,博客网站也在迅速发展。而博客的发展能改变我们的生活方式,改变我们查找资料和分享信息的方式。通过创建个人博客,我们可以在网络上拥有一块属于自己的地盘。也可以每天得到关注,其他人可以通过博客找到此人。 这样,随着时间的积累和推移,这通常被称为“个人声誉”。 个人的声誉是个人与互联网各种平台之间发展的各种关系的组合。 因此每个人的声誉也并不相同。 但是,如果为每个博客创建一种新的统一的评估审查机制,那么该机制或许将成为个人博客系统商业化的前提。
1.3 本文结构
本设计分为六个部分。首先介绍博客的历史以及现状,分析博客发展的方向。其次着重介绍本系统需要用到的相关技术。再对系统进行需求分析和可行性研究,阐述系统的可行性并确定系统的开发思想。第五部分实现系统的相关设计。第六部分对系统进行测试,验证稳定性。第七部分对博客系统的研究与设计工作进行总结,指出不足及解决方案,为以后优化打好基础。
第2章 系统的相关技术介绍
本博客系统的开发采用的是当下最流行的基于python的Flask框架,在该框架中,前端使用框架的模板引擎渲染。这样做的好处是,逻辑和前端展示分离可以方便以后维护,如果逻辑上有做修改,前端只需很少的改动,可以大大提高了系统的可复用性。在Python高开发效率的加持下,可以快速做出系统原型。
2.1 Flask简介
在python web框架的世界中,各种框架都在迅速发展,而flask便是其中之一。 Flask框架是集成了Jinja2的模板引擎的WSGI工具箱。 Flask仅有一个简单的核心,所以也被称为“微框架”。而其他功能可以通过拓展来添加。 比如Flask并默认不指定使用那种类型的数据库,没有表单的验证功能等等。正因如此,Flask保留了核心的高效性以及拓展的灵活性。 Flask的各种拓展可用于添加其他附加功能功能,如:ORM,邮件支持,表单验证工具,各种开放式身份验证技术等等。并且, Flask是采用BSD开源许可的。无需额外付费。
2.2 Bootstrap简介
Bootstrap是目前最受欢迎的前端组件库。它是推特公司开发并开源的js前端框架。主要的目的是用于快速开发和统一管理。它有效解决了传统框架在应用上的问题,如:传统框架一般都有命名复杂、样式冗余不规范、页面错乱不和谐等问题。在Bootstrap等一体化解决方案出现后,这些问题迎刃而解。Bootstrap 支持响应式布局,在最新版本中坚持以移动设备优先,可以很简便实现多设备多样式。Bootstrap一直是 GitHub 上热门的开源项目,广受各大公司推崇,包括NASA等知名网站都使用了该项目开发。
2.3 MYSQL简介
-
大量计算任务和数据,在以前只能通过人工计算,但随着技术的发展,计算机的算力提升使计算机成了大量计算最适合的工具。而计算机的发展衍生而来的数据库系统,便是是数据的结构化集合,它能使数据能被有效使用。是一种较为理想的数据处理机构。一般包括了对数据的插入、修改和检索。
-
SQL是国际标准化组织制定的用于访问和处理数据库的标准的特殊的计算机语言。而MySQL就是一种支持SQL语言的跨平台的关系型数据库管理系统。在数据库中,数据以特定的结构组织、保存在不同的数据表中,这样在访问数据时,便可以大大提高访问速度。而且拓展极为方便。
-
MySQL是一种开放源代码软件,我们可以随意浏览源代码。
-
Mysql是一个真正的多用户、多线程数据库。这些特性使mysql的速度和可靠性并不比其他商业数据库系统差。由于多线程的支持,使得mysql可以充分利用CPU资源。在最新的版本中,mysql也支持了事务化处理,因此在一般的应用系统中。它是管理数据最好的选择。
-
Mysql数据库是一个标准的C/S系统,提供TCP/IP、ODBC等多种连接途径,而且原生支持JSON。
2.4 REDIS简介
Redis是采用ANSI C语言编写的数据库。它的全称是Remote Dictionary Server,它是一直键对型数据库。
Redis也是一个开源软件,我们使用它不需要支付额外的费用。Redis的出现,很大程度上满足了关系型数据库在某些方面的不足。使用也很方便。正因如此,使用redis可以让代码变得更易维护。Redis数据库有以下几个特点:1、虽然数据保存在内存中,但支持数据持久化。2、结构简单,支持多种数据类型3、支持主从结构,效率和可靠性有保障。
2.5 NGINX简介
Nginx 是一个高性能异步框架的网页服务器。也可用作反向代理和负载均衡器。由Igor Sysoev开发。当然Nginx同时也可以作为电子邮件代理服务器。在以类BSD许可证的形式开源后,广受欢迎。在高并发使用时,cpu、内存等资源消耗依然很低,运行非常稳定。已被广泛应用于各大网站系统中。
第3章 需求分析及可行性研究
3.1 需求分析
3.1.1系统目标
系统的目标是指系统应该达到什么效果,这无关技术,就是指站在用户角度,我们的博客系统需要达到什么效果。
我们的目的是开发一个人机交互良好的博客系统,使用户能通过个人博客系统在网络上结交更多朋友,同时为用户提供记录和分享信息的平台。
3.1.2游客身份
首先,游客进入主页后可以浏览博文和发表评论,发表评论需在博客评论处输入邮箱信息,发表成功后博主可审核评论。
游客在内容划分上,主要分为一下两个部分:
-
搜索和浏览文章: 由于系统是个人博客,游客不须登录系统就可以查看博主文章,但游客不能发表文章。
-
评论文章:
对文章进行留言。
添加图片注释,不超过 140 字(可选)
图 1
3.1.3管理员身份
博主拥有自己的管理后台,可以在后台上对文章进行管理,包括发表修改和删除。同时也可以在后台对游客发表的留言进行审核,使留言展示出来或者隐藏。
个人博主在内容划分上,主要分为一下三个部分:
-
发表文章: 在管理后台上编辑和文章。
-
管理文章: 对已经发表的文章进行修改、删除等操作。
-
评论管理:
对游客以及其他用户发表的评论和留言进行审核,删除。
添加图片注释,不超过 140 字(可选)
图 2
3.2可行性研究
可行性研究的最终目的,是通过运用科学的方法验证问题是否值得解决,通常需要对项目进行全面分析。 任何项目的开始,都需要可行性研究阶段。如果在没有可行性研究的情况下盲目进行开发,则很难预测成功的可能性。
3.2.1 经济可行性
博客系统所需的硬件和软件环境(Python + MySQL)可以很轻松从市场上的相关网站购买和下载。根据不完全调查显示,各服务商的虚拟服务器成本已降到可接受的范围内,系统的成本主要是在的开发和维护上,给个人带来的经济负担并不大。使用此博客系统后,可以增加资源共享,提高资源利用率,博客可以极大地促进信息管理。另外,节省人力资源的好处远远大于开发管理系统的成本,因为目标系统并不复杂,开发周期也比较短,并且没有大量的员工支出。是可行的。
3.2.2 技术的可行性
我们的个人博客系统主要包括前端展示的开发以及后端数据库的建立。在前端展示上,我们完全有能力使其完整且易于使用,而对于后端及数据库的建立上,则需要构建具有强大数据一致性和完整性以及良好数据安全性的数据库。该系统打算分别使用基于Python的Flask框架和MS SQL作为后端数据存储的开发工具。该系统主要使用Flask框架和bootstrap等技术实现。 Python最初是被设计用于编写自动化脚本语言,具有快速开发的特性。使用它的目的为了实现快速开发。这使得开发客户端应用程序等成为可能。 Flask的模板功能提供了一种编写动态网页的更简单,更有效的方法,并增强网页程序的独立性,兼容性和可重用性。 Flask的工作模式是请求/响应模式。客户端发送一个HTTP请求。收到请求后,Flask程序对其进行处理并返回处理结果。
Mysql是一个具有完全Web支持的数据库产品。它能通过结构化查询语言(SQL)提供在互联网上进行查询的能力。它能提供基于标准SQL语言交互以及拓展数据库编程和查询功能。而得益于Flask微框架的概念。Flask的第三方扩展可以为我们提供多种数据库的接入方式。这样我们可以很轻松的接入Mysql数据库。 在大大提高开发效率的同时,它进一步扩展了应用空间并带来了新的业务应用机会。
因此从技术方面来说,此系统方案是可行的、可实际实现的。
第4章 系统总体设计
4.1系统设计原则
以上述博客系统的需求分析为出发点,本博客系统的设计应该遵循以下几个原则:
-
在产品设计上符合现今技术的潮流,技术设计具有前瞻性,但必须满足功能期望的前提。
-
系统必须操作简单,命名和技术使用满足规范型。同时具有良好的输入输出接口。
-
系统的各功能设计要完善,能够有效解决用户使用过程中出现的问题,满足用户各个方面的使用需要。
-
系统流程合理,能够符合博客管理及使用的基本操作流程。
4.2系统功能设计
4.2.1总体功能描述
博客系统主要用于使用户能够浏览博文及发表评论,博主管理相关信息,查看和相关评论,博主可以发表文章和照片上传、发送相关评论, 用于浏览和注册已注册的相册。 以及简单的后台管理。
从功能上分,本系统主要分为两个部分。由博主对博客内容进行管理的,另一部为前台游客访问和浏览博客。
-
博主管理博客 登陆功能:博主从管理后台登录,登录成功即展示后台功能。 文章管理:博主通过管理后台对文章进行管理,如发表文章和删除文章等。 留言管理:博主可以对给自己的留言查看和删除。 评论管理:博主通过管理后台对评论进行管理,如增、删、查。
-
游客浏览模块
文章查看功能:游客可以浏览文章并做出,评论显示需要博主审核。
留言板功能:给博主留言。
4.2.2功能模块设计
博客系统主要用于使用户能够浏览博文及发表评论,博主管理相关信息,查看和相关评论,博主可以发表文章和照片上传、发送相关评论, 用于浏览和注册已注册的相册。 以及简单的后台管理。
系统所实现的功能的完整性是衡量一个系统完备性的最基本标准。综合本系统各子模块要实现的功能,通过上述的需求分析。便确定了本系统的功能以及模块图。
本个人博客系统分为两个大的功能模块:前台展示(用户界面)和后台管理(博客管理)。前台展示和后台管理又分别划分为几个小的模块,如图5-2所示为博客系统的功能模块划分图:
添加图片注释,不超过 140 字(可选)
图 3
4.2.2数据库设计
4.3数据库设计概念
从概念上看,为给定的应用系统构造最优的数据存储模式,就是数据库设计。它的目的是使系统与数据库相关联。它能最大程度上影响数据的存储的方式,合理的数据存储模式能够直接影响到系统功能的实现。
4.3.1数据库逻辑结构设计
独立于任何一种数据库模型的设计,即概念设计。它是通过对需求的综合分析而形成的独立的概念结构。它是对用户需求的一种抽象表达方式。本博客系统的实体有:博主/管理员实体、游客实体、文章实体、文章标签实体、评论实体、文章类型实体。将概念设计所得的E-R图如图4-1所示
添加图片注释,不超过 140 字(可选)
图 4
4.3.2数据库物理设计
在数据库的选择中,本博客系统选用了开源的Mysql数据库,数据库名为mydb。数据库中表主要有管理员用户表、日志表、评论表、说说表、相册表、设置表。
管理员表主要拥有管理员id字段,用户名,密码字段,如下表:
表1 管理员表
名称 | 类型 | 说明 | 是否为空 | 备注 |
---|---|---|---|---|
id | int(11) | 管理员编号 | 否 | 主键 |
site_name | varchar(10) | 主页Logo | 是 | |
site_title | varchar(255) | Logo小标题 | 是 | |
name | varchar(10) | 博客名 | 是 | |
profile | varchar(255) | 个性签名 | 是 | |
login_name | varchar(500) | 管理员账号 | 是 | |
password_hash | varchar(500) | 管理员密码 | 是 | |
record_info | varchar(255) | 拓展 | 是 |
分类表有分类id、分类名字段,如下表:
表2 分类表
名称 | 类型 | 说明 | 是否为空 | 备注 |
---|---|---|---|---|
id | int(11) | 标签编号 | 否 | 主键 |
category | varchar(6) | 分类名 | 否 |
标签表有标签id、标签名字段,如下表:
表3 标签表
名称 | 类型 | 说明 | 是否为空 | 备注 |
---|---|---|---|---|
id | int(11) | 标签编号 | 否 | 主键 |
category | varchar(25) | 标签名 | 否 |
标签表有评论id、评论、评论者名称、评论者邮箱字段,如下表:
表4 评论表
名称 | 类型 | 说明 | 是否为空 | 备注 |
---|---|---|---|---|
id | int(11) | 评论编号 | 否 | 主键 |
comment | text | 评论 | 是 | |
author | varchar(25) | 评论者名称 | 是 | |
| varchar(255) | 评论者邮箱 | 是 | |
website | varchar(255) | 保留 | 是 | |
isReply | tinyint(1) | 是否首层评论 | 是 | |
disabled | int(11) | 是否显示 | 是 | |
record_info | tinyint(1) | 是否通过审核 | 是 | |
timestamp | datetime | 时间 | 是 | |
post_id | int(11) | 文章编号 | 是 | |
page_id | int(11) | 保留 | 是 | |
article_id | int(11) | 保留 | 是 |
文章表主要有分类id、文章、标题、时间字段,如下表:
表5 文章表
名称 | 类型 | 说明 | 是否为空 | 备注 |
---|---|---|---|---|
id | int(11) | 文章编号 | 否 | 主键 |
title | varchar(64) | 文章名 | 是 | |
url_name | varchar(64) | 文章连接 | 是 | |
timestamp | varchar(64) | 发布时间 | 是 | |
body | test | 文章内容 | 是 | |
draft | tinyint(1) | 是否草稿 | 是 | |
disable | tinyint(1) | 是否发布 | 是 | |
tags | varchar(64) | 文章标签 | 是 | |
category_id | int(11) | 分类名 | 是 |
第5章 主要功能的实现
5.1后台登录
首先编写前端展示的页面,创建登录表单
...
<div class="login-input">
<form action="{ { url_for('admin.login') }}" method="post">
{ {form.hidden_tag()}}
<p>用户:{ {form.username(class="login")}}</p>
<p>密码:{ {form.password(class="login")}}</p>
<p>记住:{ {form.remember_me}}</p>
<p><input class="but" type="submit" value="登录"></p>
</form>
</div>
...
创建表单后,前端页面已经可以看到登录界面了,接下来定义登录接口,绑定路由并添加处理函数
@admin.route('/login/', methods=['GET', 'POST'])#绑定路由
def login():#登录处理函数
form = AdminLogin()#创建用户对象
if form.validate_on_submit():#提交数据处理逻辑
user = Admin.query.filter_by(login_name=form.username.data).first()
if user is not None and user.verify_password(form.password.data):
login_user(user, form.remember_me.data) #校验用户名和密码
return redirect(url_for('admin.index')) #验证成功重定向
flash('账号或密码无效。')#验证失败返回提示
return render_template('admin/login.html',title='登录',form=form)
用户界面如图5所示,填写正确的用户名和密码即可登录成功,在未登录的情况下进入其他页面,会跳转回到登录页,实现登录界面如下:
添加图片注释,不超过 140 字(可选)
图 5 登录页面
用户如果账号密码验证失败,会在上方返回提示,首先界面如下图:
添加图片注释,不超过 140 字(可选)
图 6 登录失败
5.2文章发表
编写前端模板
...
<div class="data-ipt">
<p>分类:{ {form.category(placeholder="只能写一个")}}</p>
<p>标签:{ {form.tags(placeholder="用英文逗号隔开")}}</p>
<p>链接:{ {form.url_name(placeholder="url文章名")}}</p>
<p>日期:{ {form.time(placeholder="使用-连接年月日")}}</p>
</div>
...
编写处理函数
@admin.route('/write', methods=['GET', 'POST'])#代理路由,绑定到/write
@login_required#此页面需要登录
def write():#逻辑处理函数
form = AdminWrite()#生成表单对象
if form.validate_on_submit():# 保存草稿
if 'save_draft' in request.form and form.validate():
post = save_post(form, True)
db.session.add(post)
flash('保存成功!')# 发布文章
elif 'submit' in request.form and form.validate():
post = save_post(form)
db.session.add(post)
flash('发布成功!')
db.session.commit()
return redirect(url_for('admin.write'))
return render_template('admin/admin_write.html',form=form, title='写文章')
实现效果
添加图片注释,不超过 140 字(可选)
图 7 发表文章界面
5.3用户评论
在文章的浏览页面加入一个表单,用来接收用户的评论以及一些用户信息,主要代码主要如下:
def save_comment(post, form):
base_url = current_app.config['WEB_URL'] # 站点链接
...
if replyTo: #判断评论是否为主评论
comment = '<p class="reply-header"><a class="comment-user" href="' + website +'" target="_blank">'+ nickname + '</a>'+ '<span>回复</span> ' + replyName + ':</p>\n\n' + com
else:
comment = '<p class="reply-header">' + nickname + '<span>回复</span> ' + replyName + ':</p>\n\n' + com
db.session.add(comment)#将评论添加到数据库会话
db.session.commit()#将会话提交保存
return data
执行过程如下,在文章下方输入评论和邮箱如图:
添加图片注释,不超过 140 字(可选)
图 8 评论框
系统首先会检查个人信息是否符合规范,不符要求则返回错误
添加图片注释,不超过 140 字(可选)
图 9 错误提示
修改正确后,再次提交,成功后返回需要审核信息。
添加图片注释,不超过 140 字(可选)
图 10 提交评论成功
5.4修改文章
首先将提交按钮绑定到路由'/edit/<int:time>/<name>'中,。主要代码主要如下:
if post.draft is True:
if 'save_draft' in request.form and form.validate():
db.session.add(post)
flash('成功保存!')
elif 'submit' in request.form and form.validate():
post.draft = False
db.session.add(post)
db.session.commit()
flash('修改成功')
return redirect(url_for('admin.admin_edit', time=post.timestampInt, name=post.url_name))
点击编辑后,跳入文章编辑页面,修改完成,点击更新按钮,系统执行上述代码段保存修改。首先界面如图:
添加图片注释,不超过 140 字(可选)
图 11 文章管理
点击更新后,返回更新结果:
添加图片注释,不超过 140 字(可选)
图 12 修改结果
5.5评论审核
评论审核主要逻辑代码如下,在把函数绑定url后,函数接收评论状态并提交数据库修改:
@admin.route('/allow/comment/<int:id>')#绑定路由
@login_required #此接口需要登录
def allow(id):#逻辑处理函数
comm = Comment.query.get_or_404(id)#获取评论对象
comm.disabled = True#设置显示标志
db.session.add(comm)#提交数据库会话
db.session.commit()#保存修改
flash('允许通过')#返回提示
评论审核主页面:
添加图片注释,不超过 140 字(可选)
图 13 评论管理主页面
5.6数据接口
为了首先和前台的交互,以及方便我们获取服务端数据,我们把数据获取的方式全部统一放在api文件中,数据获取全部这一文件中实现。如,获取文章的接口主要代码主要如下:
@api.route('/posts') #绑定路由
def get_pos(): #具体处理函数
page = request.args.get('page', 1, type=int) #获取分页
pagination = Post.query.order_by(Post.timestamp.desc()).paginate(
page, per_page=current_app.config['POSTS_PER_PAGE'],error_out=False)
posts = [post for post in pagination.items if post.draft is False]
prev = None
if pagination.has_prev:
prev = url_for('api.get_posts', page=page - 1, _external=True)
next = None
if pagination.has_next:
next = url_for('api.get_posts', page=page + 1, _external=True)
return jsonify({ 'posts': [post.to_json() for post in posts],'prev': prev,'next': next,'count': pagination.total})
第6章 系统测试
6.1系统测试的目的
测试是具有试验性质的测量,软件测试的目的是在程序上线前,尽可能多的测试出BUG。进行系统测试是保证系统质量不可或缺的一步。首先,测试不仅仅是为了找出错误。也是为了通过分析错误的过程,完善程序本身。
6.2系统测试的方法
系统测试的方法主要有黑盒测试和白盒测试,主要从从是否关心内部结构的层面区分。
白盒测试也称驱动测试,它是在知晓内部细节的情况下,测试产品的内部动作是否正常进行,验证程序是否按预定正常运作。我们通过把整个程序当成一个被打开的盒子,在知悉实现细节的情况下测试实际状态是否符合预期。
黑盒测试也称为数据驱动测试,我们把整个程序当成一个黑盒子,我们在不了解细节的情况下,通过输入输出检查程序是否正常运行。
在我们的系统中,主要用到黑盒测试。
6.3系统测试用例
在我们的系统中,主要用到黑盒测试。
-
博客管理员登录测试 测试内容:在博客的管理后台上输入账号信息,验证是否能登录结果。 操作:①在正确位置填写正确的账号、密码,点击提交。 ②在正确位置填写错误的账号、密码,点击提交。 结果:①登录成功,返回博客后台界面首页。 ②登录失败,提示重新登陆。
添加图片注释,不超过 140 字(可选)
图 14 登录成功
添加图片注释,不超过 140 字(可选)
图 15 登录失败
-
文章发表测试 测试内容:发表新博文 操作:首先登录管理后台,取得权限后进入文章发表界面,输入文章标题,文章时间,文章内容,点击提交。 结果:文章发表成功
添加图片注释,不超过 140 字(可选)
图 16 发表文章
-
游客对文章进行评论 测试内容:评论文章 操作:游客进入博客系统首页,在首页浏览文章并打开文章后,在文章下方输入个人信息和评论内容后,点击提交。 结果:显示评论成功
添加图片注释,不超过 140 字(可选)
图 17 输入评论
添加图片注释,不超过 140 字(可选)
图 18 评论成功
-
审核评论 测试内容:对评论进行审核 操作:管理员登录管理后台,在后台选择评论管理,在评论管理页面对评论进行显示或删除操作。 结果:评论审核成功
添加图片注释,不超过 140 字(可选)
图 19 评论审核页面
添加图片注释,不超过 140 字(可选)
图 20 通过评论
第7章 总结与展望 7.1博客系统的主要特点 本设计基于综合Python语言,合理运用了web框架、数据库等技术,详细阐述了基于Flask的博客系统的分析与实现过程,采用了Flask设计,从职责上分为三部分:前端模板、数据处理、数据传输。其中使用Flask框架作为系统的整体基础。 主要特点有:
-
利用Flask-admin的组件实现了图片的快速上传功能,使得用户对相册的管理更加的快捷方便。
-
链接好友的博客,评论可自定义链接,使交流也更加的方便。
-
用户可以根据文章所属的类别、标签查看同一类别、标签下的所有文章。
7.2系统的不足之处
首先,访问者可以在进入主页后查看博客文章以及发表评论。要发表评论,必须在博客的评论部分中输入电子邮件信息。
该系统基本上可以满足整个博客的功能要求,但是由于本博客系统的设计还不够广泛,市场上已近有有许多成熟的博客系统,由于知识和时间的限制,该系统仍然存在一些限制、缺陷。需要进一步调查和改进。系统设计的弊端主要体现在以下几个方面:
(1)由于对前端页面布局的了解有限,因此该系统的界面相对不专业,可能需要在交互上的优化。
(2)由于在前期开发过程中,代码设计并不完善,虽然勉强实现了相同的效果,但是代码并不简洁明了,需要质量上的优化。
(3)由于时间的限制,以后的测试可能会比较粗糙,并且BUG的程度可能会有所不同,因此在未来的设计中需要做出相应的改进和修正。
7.3前景展望
首先,用户可以在进入主页后查看博客文章并发表评论。要发表评论,则必须在博客的评论部分中输入电子邮件信息。
在各种领域全球化发展的现在,封闭的国家无法跟上发展的潮流,这是一个供人的事实,个人博客的发展亦是如此,信息交流的过程是一个没有界限的交流过程。建立个人博客是为了满足人们对这种交流的需要。有了个人博客,使得每个人都可以构建一个在全球化过程中可以自由发布信息的平台。这是互联网给人们生活带来的变革。
个人博客平台的发展和进步是一个必然的过程。信息的全球化,为人们接触更多的信息提供了机会与平台。把人们带入交互式网络社会的同时,也突破了不同地区人与人之间的障碍,在给人们带来机会的同时,也为人们的发展以及眼界的提升带来了前所未有机遇。这样一个开放的世界使得我们更加的关注个性化的人们,追求各种文化和精神创造力,并引起人们对全球化背景的关注。
因此,研发一个完善的博客系统,是使未来的互联网通信过程更加方便和易于交互的必然趋势。
参考文献:
[1]胡小丽,徐远纯.基于python的博客分层聚类研究与分析[J].福建电脑,2012,28(05):98-99.
[2] 李超,徐云龙,华中伟,史梦安,张滢.一种基于Python Flask的Web服务器端设计[J].信息与电脑(理论版),2019(08):87-88.
[3] 马旭,王淑丽.基于Flask框架的展示型网站的设计与实现[J].数字技术与应用,2018,36(11):137-138.
[4] 叶锋.Python最新Web编程框架Flask研究[J].电脑编程技巧与维护,2015(15):27-28.
[5]郑阿奇.SQL Server 实用教程(第2 版)[M].北京:电子工业出版社,2005
[6] Magnus Lie Hetland. Python基础教程(第3版)[M].袁国忠. 译. 人民邮电出版社, 2018
[7] Luciano Ramalho.流畅的Python[M].安道,吴珂. 译. 人民邮电出版社, 2017
[8]岳 浩.Linux操作系统教程[M] .机械工业出版社 2005
[9]杜波依斯. MySQL技术内幕[M]. 第4版. 人民邮电出版社 , 2011
[10] 李辉. Flask Web开发实战[M]. 第2版. 电子工业出版, 2018
[11] 美福达. SQL必知必会[M]. 人民邮电出版社.2013
[12] Meng Christian,Baier Harald. bring2lite: A Structural Concept and Tool for Forensic Data Analysis and Recovery of Deleted SQLite Records[J]. ,2019,29(S).
[13] Li Zhang,Shengang Hao,Quanxin Zhang. Recovering SQLite data from fragmented flash pages[J]. Annals of Telecommunications,2019,74(7-8).