Flask蓝图遇到的问题

欢迎加入python学习交流群 667279387

最近在使用flask开发一个业余学习项目,由于之前都是“小打小闹”,整个程序都是放在一个文件夹里面的,也没有注意这个问题。这次项目整的稍微正规一点,发现自己没有吃透flask蓝图的功能。这里记录一下自己遇到的问题,方便以后查阅。

问题:

注册了蓝图,但是找不到对应的URL。后来发现是自己没有正确使用蓝图。

原因

下面以一个简单的示例框架进行说明。首先看下本次示例代码矿建,这也是flask框架项目的常用架构。

root@Ubuntu:~/website# tree
.
├── app
│   ├── __init__.py
│   ├── main
│   │   ├── __init__.py
│   │   └── views.py
│   └── models.py
└── manager.py

2 directories, 5 files

整个项目在website文件夹下面,底层的架构如上图所示。
下面来看看这个文件具体作用:
1、manager.py 用来启动整个程序。只需要在website目录下面执行:python manager.py就启动了整个flask项目。
下面是manager.py中的详细内容

root@Ubuntu:~/website# cat manager.py 
from app import create_app

app = create_app()

if __name__ == '__main__':
    app.run()

2、app/__init__.py文件,定义了用来创建app的函数。具体如下:

from flask import Flask

def create_app():
    app = Flask(__name__)

    from .main import main as main_blueprint
    app.register_blueprint(main_blueprint)

    return app

当然此处定义的比较简单,没有注册其他的组件。例如数据库的初始化。

from flask_sqlalchemy import SQLAlchemy
db=SQLAlchemy()
def create_app():
    app = Flask(__name__)

    #初始化数据库
    db.init_app(app)
    db.create_all()

    from .main import main as main_blueprint
    app.register_blueprint(main_blueprint)

    return app

当然其他的插件类似。

3、models.py这个里面主要是ORM的实现。本文没有用到这个数据库。所以里面是空的。

4、main/__init__.py:里面是蓝图的初始化。

from flask import Blueprint

main = Blueprint("main",__name__)

from . import views

里面只有三行代码。一开始我没有将views导入到里面,导致找不到URL。所以后续如果要再在main文件夹里面增加views文件,就必须也要import进去。否则就会提示找不到URL。

5、views.py:一个hello world 测试页面。

from . import main

@main.route("/",methods=["GET"])
def index():
     return "hello world!\n"

整个项目框架就算完成了。当然后续有其他的蓝图要添加,可以和main一样操作添加即可。另外的templates和static文件都放在app这个目录下面即可。

程序运行结果。

root@Ubuntu:~/website# python manager.py 
 * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
127.0.0.1 - - [27/Dec/2017 12:56:13] "GET / HTTP/1.1" 200 -
root@Ubuntu:~# curl -X GET http://127.0.0.1:5000/
hello world!

这个框架讲的比较简单,可以参考《Flask Web开发:基于Python的Web应用开发实战》作者在github上面的代码进行进一步学习。

欢迎加入python学习交流群 667279387

猜你喜欢

转载自blog.csdn.net/hjxzb/article/details/78910832