前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Flask 系列之 优化项目结构

Flask 系列之 优化项目结构

作者头像
py3study
发布2020-01-16 11:28:53
4700
发布2020-01-16 11:28:53
举报
文章被收录于专栏:python3

说明

  • 操作系统:Windows 10
  • Python 版本:3.7x
  • 虚拟环境管理器:virtualenv
  • 代码编辑器:VS Code

实验目标

完善环境配置,添加 异常请求 处理

实现

400、404 和 500 处理

首先,在 todolist\app\templates\errors 目录下创建一个 400.html 文件,示例代码如下所示:

代码语言:javascript
复制
{% extends 'base.html' %} {% block content %}
<div class="text-center animated fadeInDown">
    <h1>400</h1>
    <h3> 错误请求!! !</h3>
    <div>
        <a href="{{ url_for('index') }}">返回首页</a>
    </div>
</div>

{% endblock %}

todolist\app\templates\errors 目录下创建一个 404.html 文件,示例代码如下所示:

代码语言:javascript
复制
{% extends 'base.html' %} {% block content %}
<div class="text-center animated fadeInDown">
    <h1>404</h1>
    <h3> 页面未能够找到!! !</h3>
    <div>
        抱歉,页面好像去火星啦!
    </div>
</div>

{% endblock %}

todolist\app\templates\errors 目录下创建一个 500.html 文件,示例代码如下所示:

代码语言:javascript
复制
{% extends 'base.html' %} {% block content %}
<div class="text-center animated fadeInDown">
    <h1>500</h1>
    <h3> 内部异常!! !</h3>
    <div>
        <a href="{{ url_for('index') }}">返回首页</a>
    </div>
</div>

{% endblock %}

接着,在 todolist\app 目录下创建 errors.py 文件,,注册 400、 404 、500 路由处理函数,示例代码如下所示:

代码语言:javascript
复制
from flask import render_template
from app import app


@app.errorhandler(400)
def bad_request(e):
    return render_template('errors/400.html'), 400


@app.errorhandler(404)
def page_not_found(e):
    return render_template('errors/404.html'), 404


@app.errorhandler(500)
def internal_server_error(e):
    return render_template('errors/500.html'), 500

添加 CLI

todolist\app 目录下创建 commands.py 文件,示例代码如下所示:

代码语言:javascript
复制
import click
from app import app, db
from app.models import User, Thing


@app.cli.command()
@click.option('--drop', is_flag=True, help='Create after drop.')
def initdb(drop):
    if drop:
        db.drop_all()
    db.create_all()
    print("Initialized database.")


@app.cli.command()
@click.option('--username', prompt=True, help='The username used to login.')
@click.option('--email', prompt=True, help='The email used to Identity.')
@click.option('--password', prompt=True, hide_input=True, confirmation_prompt=True, help='The password used to login.')
def admin(username, email, password):
    db.create_all()
    user = User.query.first()
    if user:
        print("Updating user...")
        user.name = username
        user.email = email
        user.generate_password_hash(password)
    else:
        print("Creating user...")
        user = User(name="hippieZhou")
        user.email = email
        user.generate_password_hash(password)
        db.session.add(user)
    db.session.commit()
    print('Done.')

此时,可以将 VS Code 的终端却换至该项目根目录下,可执行上面我们自定义的相关目录,如下图所示:

使用前需要先进入到 app 中,具体可参考 下面的 todolist\app\__init__.py 代码。

完善 Config 配置

首先,修改 todolist\config.py 文件,示例代码如下所示:

代码语言:javascript
复制
import os

basedir = os.path.abspath(os.path.dirname(__file__))


class Config(object):
    SQLALCHEMY_TRACK_MODIFICATIONS = False
    SECRET_KEY = "you will never known it."


class DevelpmentConfig(Config):
    DEBUG = True
    SQLALCHEMY_DATABASE_URI = os.environ.get(
        'DEV_DATABASE_URL') or 'sqlite:///' + os.path.join(basedir, 'todo.sqlite')


class ProductionConfig(Config):
    DEBUG = False
    SQLALCHEMY_DATABASE_URI = os.environ.get(
        'SQLALCHEMY_DATABASE_URI') or 'mysql+pymysql://root:mysql@127.0.0.1:3306/todo'


config = {
    'development': DevelpmentConfig,
    'production': ProductionConfig
}

接着,修改 todolist\app\__init__.py 文件,示例代码如下所示:

代码语言:javascript
复制
from flask import Flask
from flask_bootstrap import Bootstrap
from flask_sqlalchemy import SQLAlchemy
from flask_login import LoginManager
from config import config

app = Flask(__name__)
app.config.from_object(config['development'])

bootstrap = Bootstrap(app)

db = SQLAlchemy(app)

login_manager = LoginManager(app)

login_manager.login_view = 'login'
login_manager.login_message = '你必须登陆后才能访问该页面'
login_manager.login_message_category = "info"

@login_manager.user_loader
def load_user(user_id):
    from app.models import User
    user = User.query.get(int(user_id))
    return user

@app.context_processor
def inject_user():
    from app.models import User
    user = User.query.first()
    return dict(user=user)

from app import views, errors,commands

最后,修改 todolist\manage.py 文件,示例代码如下所示:

代码语言:javascript
复制
from app import app


if __name__ == "__main__":
    app.run(debug=True, host='0.0.0.0', port=5000)

自此,我们的项目结构和代码已经进一步完善了,完整项目结构如下图所示:

最后,我们可以在 Shell 窗口中执行 flask run 命令即可将我们的网站运行起来。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019/05/23 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 说明
  • 实验目标
  • 实现
    • 400、404 和 500 处理
      • 添加 CLI
        • 完善 Config 配置
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档