实验知识点
- 项目创建
- 基本配置
实验环境
- Python 3.4
- Flask 1.0.2
注意:实验环境可以按自己的来
这里我们将博客应用起名为simp_blog
,基本上我们想要它做如下的事情:
- 根据配置文件中的认证允许用户登录以及注销。仅仅支持一个用户。
- 当用户登录后,他们可以添加新的条目,这些条目是由纯文本的标题和 HTML 的正文构成。因为我们信任用户这里的 HTML 是安全的。
- 页面倒序显示所有条目(新的条目在前),并且用户登入后可以在此添加新条目。
我们将在这个应用中直接使用 SQLite 3 因为它足够应付这种规模的应用。对更大的应用使用 SQLAlchemy 是十分有意义的,它以一种更智能方式处理数据库连接,允许你一次连接多个不同的关系数据库。你也可以考虑流行的 NoSQL 数据库,前提是你的数据更适合它们。
创建文件夹:
mkdir simp_blog && cd simp_blog
mkdir static templates
其中:
- simp_blog:项目总文件夹。其中会存放数据库代码文件
schema.sql
和 主代码文件simp_blog.py
。 - static:项目的资源文件。用于存放
css
和javascript
文件。 - templates:项目前端页面文件。用于存放前端页面模板。
数据库模式:
对于这个应用仅一张表就足够了,而且我们只想支持 SQLite ,所以很简单。在 simp_blog
目录下新建 schema.sql
文件并向其中写入如下代码:
drop table if exists entries;
create table entries (
id integer primary key autoincrement,
title string not null,
text string not null
);
这个模式由一个称为entries
的单表构成,在这个表中每行包含一个id
,一个title
和一个text
。id
是一个自增的整数而且是主键,其余两个为非空的字符串。
现在我们已经有了数据库模式了,可以创建应用的模块了。
在 Code/simp_blog
目录下新建 simp_blog.py
文件。对于小应用,直接把配置放在主模块里,正如我们现在要做的一样,这是可行的。然而一个更干净的解决方案就是单独创建.ini
或者.py
文件接着加载或者导入里面的值。
在 simp_blog.py
文件中写入如下代码:
# 导入所有的模块
import sqlite3
from flask import Flask, request, session, g, redirect, url_for, abort, render_template, flash
# 配置文件
DATABASE = '/tmp/flaskr.db'
ENV = 'development'
DEBUG = True
SECRET_KEY = 'development key'
USERNAME = 'admin'
PASSWORD = 'default'
下一步我们能够创建真正的应用,修改 simp_blog.py
文件在其中配置初始化:
# 创建应用
app = Flask(__name__)
app.config.from_object(__name__)
from_object()
将会寻找给定的对象(如果它是一个字符串,则会导入它),搜寻里面定义的全部大写的变量。在我们的这种情况中,配置文件就是我们上面写的几行代码。 你也可以将他们分别存储到多个文件。
通常从配置文件中加载配置是一个好的主意。这时可以使用from_envvar()
来实现,可以用它替换上面的from_object()
:
app.config.from_envvar('FLASKR_SETTINGS', silent=True)
这种方法我们可以设置一个名为FLASKR_SETTINGS
的环境变量来设定一个配置文件载入后是否覆盖默认值。静默开关silent=True
告诉 Flask 不去关心这个环境变量键值是否存在。
SECRET_KEY
是为了保持客户端的会话安全。明智地选择该键,使得它难以猜测,最好是尽可能复杂。
DEBUG 调试标志启用或禁用交互式调试。决不让调试模式在生产系统中启动,因为它将允许用户在服务器上执行代码!
我们还添加了一个轻松地连接到指定数据库的方法,这个方法用于在请求时打开一个连接,并且在交互式 Python shell 和脚本中也能使用,这将方便后面的使用。
在 Code/simp_blog.py
文件中继续添加如下代码:
#数据库设置
def connect_db():
return sqlite3.connect(app.config['DATABASE'])
最后如果我们想要把这个文件当做独立应用来运行,只需在服务器启动文件也就是 Code/simp_blog.py
文件的末尾添加这一行:
if __name__ == '__main__':
app.run()
如此我们便可以顺利开始运行这个应用,通过使用如下命令:
python3 simp_blog.py
* Serving Flask app "simp_blog" (lazy loading)
* Environment: development
* Debug mode: on
* Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
* Restarting with stat
* Debugger is active!
* Debugger PIN: 599-111-015
当你在浏览器中访问服务器获得一个 404 Not Found
的错误时,是因为我们还没有任何视图。