美文网首页
flask.pocoo.org/docs/0.12——appli

flask.pocoo.org/docs/0.12——appli

作者: 催眠_a363 | 来源:发表于2017-10-28 17:10 被阅读0次

    写在开头:使用Pycharm创建installation.md文件,Pycharm居然不能识别,好奇怪,不得不改名了!

    原文地址

    Table Of Contents

    Installation

    版本

    开发版(不稳定)
    Flask 0.12.x(稳定版)
    Flask 0.11.x
    Flask 0.10.x

    PALLETS

    The Pallets Projects are a collection of Python web development libraries.

    相关主题(Related Topics)

    文档预览

    步骤二:初始化应用程序

    现在已经有数据库方案了,所以接下来你可以创建程序模块了,flask.py。这个文件需要放置在flask/flask目录下,
    在模块开始的几行是很重的必需的声明,之后是几行配置代码。对于像flaskr一样的小型应用来说,可以把配置
    代码放在这同一个模块中。但是一个更明朗的解决方案是,单独创建一个 .init 或者 .py 文件,下载,然后从它引入值。

    如下的是引入声明(在flaskr.py文件中):

    # all the imports
    import os
    import sqlite3
    from flask import Flask, request, session, g, redirect, url_for, abort,\
        render_template, flash
    

    接下来的几行代码将会创建实例,并用同一个文件里的配置初始化它flaskr.py:

    app = Flask(__name__) #create the application instance :)
    app.config.from_object(__name__) #load config from this file, flaskr.py
    
    #load default config and override config from an environment variable
    app.config.update(dict(
        DATABASE = os.path.join(app.root_path, 'flaskr.db'),
        SECRET_KEY = 'development key',
        USERNAME = 'admin',
        PASSWORD = 'default'
    ))
    app.config.from_envvar('FLASKR_SETTINGS', silent=True)
    

    Config对象,类似一个字典,所以可以使用新值替换。

    数据库路径

    操作系统知道当前进程的路径,不幸的是,对于web应用程序来时,不能这样认为,因为在一个进程中也许有多个程序在运行。

    鉴于此,app.root_path 属性可以被用来获取应用程的路径。配合 os.path 使用,可以很轻易地找到文件。
    在这个例子中,我们把数据库文件就放在与它同级目录旁边。

    对于一个真的应用来说,建议使用实例文件夹

    通常来说,加载一个独立的,环境配置文件是比较好的。Flask允许你引入多种不同的配置,它会使用你最后一次的引入的定义。
    强大的配置函数setups.from_envvar()可以帮助这样实现。

    app.config.from_envvar('FLASKR_SETTINGS', silent=True)
    

    简单的定义一个环境变量FLASKR_SETTINGS,使它指向一个被加载的配置文件,silent 参数用于告诉Flask,如果没有这样的一个
    环境变量的话,也可以正常运行。

    此外,你也可以使用from_object()方法,提供一个引入的模块名。Flask将会使用这个模块来初始化变量。有一点请记住,在任何
    情况下,只有大写的变量名才会被使用。

    SECRET_KEY对于保证客户端的会话安全是必要的。请明智的选择这个值,确保它很难猜到,而且足够复杂。

    最后,你要添加一个方法,使程序可以容易的链接到特定的数据库。
    这可以用于根据请求以及交互式Python shell或脚本打开链接。以后,我们会做这些。
    你可以通过SQLite创建一个简单的链接,并且告诉它使用SQLite3.Row对象展示数据表中的行。这可以使他们像字典一样,而不是元组。

    def connect_db():
        """Connects to the specific database."""
        rv = sqlite3.connect(app.config['DATABASE'])
        rv.row_factory = sqlite3.Row
        return rv
    

    在下一部分,你将会看到如何运行程序。

    请看下一步:步骤三:以包的形式安装flaskr

    相关文章

      网友评论

          本文标题:flask.pocoo.org/docs/0.12——appli

          本文链接:https://www.haomeiwen.com/subject/wwyspxtx.html