### 导航
- [索引](# "总目录")
- [下一页](# "步骤 3: 创建数据库") |
- [上一页](# "步骤 1: 数据库模式") |
- [Flask 0.10.1 文档](#) »
- [教程](#) »
# 步骤 2: 应用设置代码
现在我们已经有了数据库模式,我们可以创建应用的模块了。让我们叫它 flaskr.py ,并放置在 flaskr 目录下。为面向初学者,我们会添加所有需要的导入像配置的章节中一样。对于小应用,直接把配置放在主模块里,正如我们现在要做的一样,是可行的。但是,一个更简洁的方案是创建独立的 .ini 或 .py 文件,并载入或导入里面的值。
flaskr.py 中
~~~
# all the imports
import sqlite3
from flask import Flask, request, session, g, redirect, url_for, \
abort, render_template, flash
# configuration
DATABASE = '/tmp/flaskr.db'
DEBUG = True
SECRET_KEY = 'development key'
USERNAME = 'admin'
PASSWORD = 'default'
~~~
接下来我们要创建真正的应用,并且在同一个文件 flaskr.py 中配置并初始化:
~~~
# create our little application :)
app = Flask(__name__)
app.config.from_object(__name__)
~~~
[from_object()](# "flask.Config.from_object") 会遍历给定的对象(如果它是一个字符串,则会导入它),搜寻里面定义的全部大写的变量。这种情况,配置文件就是我们上面写的几行代码。你也可以将他们分开存储到多个文件。
从一个配置文件导入配置通常是个好主意。 [from_envvar()](# "flask.Config.from_envvar")也能做到,用它替换上面的 [from_object()](# "flask.Config.from_object") 一行:
~~~
app.config.from_envvar('FLASKR_SETTINGS', silent=True)
~~~
这种方法我们可以设置一个名为 FLASKR_SETTINGS 环境变量来设定一个配置文件载入后是否覆盖默认值。静默开关告诉 Flask 不去关心这个环境变量键值是否存在。
我们需要 secret_key 来保证客户端会话的安全。一个尽可能难猜测,尽可能复杂的密钥是正确的选择。调试标志关系交互式调试器的开启。 *永远不要在生产系统中激活调试模式* ,因为它将允许用户在服务器上执行代码。
我们还添加了一个快速连接到指定数据库的方法,这个方法用于在请求时打开一个连接,并且在交互式 Python shell 和脚本中也能使用。这对以后很方便。
~~~
def connect_db():
return sqlite3.connect(app.config['DATABASE'])
~~~
最后,如果我们想要把那个文件当做独立应用来运行,我们只需在服务器启动文件的末尾添加这一行:
~~~
if __name__ == '__main__':
app.run()
~~~
如此我们便可以顺利开始运行这个应用,使用如下命令:
~~~
python flaskr.py
~~~
你将会看见有消息提示你可以访问服务器的地址。You will see a message telling you that server has started along withthe address at which you can access it.
当你在浏览器中访问服务器获得一个 404 page not found 错误时,是因为我们还没有任何视图。我们之后再来关注这些。首先我们应该让数据库工作起来。
外部可见的服务器
想要你的服务器公开可见? [*外部可见的服务器*](#)一节有更多信息。
继续 [*步骤 3: 创建数据库*](#) 。
© 版权所有 2013, Armin Ronacher.
- 欢迎使用 Flask
- 前言
- 给有经验程序员的前言
- 安装
- 快速入门
- 教程
- 介绍 Flaskr
- 步骤 0: 创建文件夹
- 步骤 1: 数据库模式
- 步骤 2: 应用设置代码
- 步骤 3: 创建数据库
- 步骤 4: 请求数据库连接
- 步骤 5: 视图函数
- 步骤 6: 模板
- 步骤 7: 添加样式
- 福利: 应用测试
- 模板
- 测试 Flask 应用
- 记录应用错误
- 配置处理
- 信号
- 即插视图
- 应用上下文
- 请求上下文
- 用蓝图实现模块化的应用
- Flask 扩展
- 与 Shell 共舞
- Flask 代码模式
- 大型应用
- 应用程序的工厂函数
- 应用调度
- 使用 URL 处理器
- 部署和分发
- 使用 Fabric 部署
- 在 Flask 中使用 SQLite 3
- 在 Flask 中使用 SQLAlchemy
- 上传文件
- 缓存
- 视图装饰器
- 使用 WTForms 进行表单验证
- 模板继承
- 消息闪现
- 用 jQuery 实现 Ajax
- 自定义错误页面
- 延迟加载视图
- 在 Flask 中使用 MongoKit
- 添加 Favicon
- 数据流
- 延迟请求回调
- 添加 HTTP Method Overrides
- 请求内容校验码
- 基于 Celery 的后台任务
- 部署选择
- mod_wsgi (Apache)
- 独立 WSGI 容器
- uWSGI
- FastCGI
- CGI
- 聚沙成塔
- API
- JSON 支持
- Flask 中的设计决策
- HTML/XHTML 常见问题
- 安全注意事项
- Flask 中的 Unicode
- Flask 扩展开发
- Pocoo 风格指引
- Python 3 支持
- 升级到最新版本
- Flask Changelog
- 许可证
- 术语表