我有一个蓝图对象" api"和一个apis.py文件,其中我有许多API使用api.route注释定义。例如:
@api.route('/', methods=['GET'])
def get_info():
我想迭代并获得所有API的摘要,这些API与我们使用" url_map.iter_rules"时得到的相同。在app对象上。我们如何使用api蓝图对象来做到这一点?我已使用
在init.py文件中注册了蓝图from .api_1 import api as api_blueprint
app.register_blueprint(api_blueprint)
答案 0 :(得分:1)
我认为如果您在注册蓝图后拨打app.url_map.iter_rules()
,您也会获得子域的所有端点,例如。
api.py
from flask import Blueprint
api = Blueprint('api', __name__)
@api.route('/')
def call_api():
return ""
init.py:
from flask import Flask, Blueprint
from api import api
public = Blueprint('public', __name__)
@public.route('/')
def home():
return render_template('public/home.html')
app = Flask(__name__)
app.register_blueprint(public)
app.register_blueprint(api, subdomain='api')
print(list(app.url_map.iter_rules()))
[<Rule 'api|/' (GET, HEAD, OPTIONS) -> api.call_api>,
<Rule '/' (GET, HEAD, OPTIONS) -> public.home>,
<Rule '/static/<filename>' (GET, HEAD, OPTIONS) -> static>]
答案 1 :(得分:1)
如果你觉得它有用,我做了一个函数,它根据在主应用程序中注册的蓝图向我显示(仅用于测试)每个 url。 这是我发现的唯一能够打印端点的解决方案,这些端点由它们所属的蓝图分隔。 当然,您可以创建一个函数,通过以字符串格式传递名称或蓝图本身,从而能够仅打印其中一个蓝图的 url_map。 以下是示例:
from flask.logging import create_logger
def log_routes(app: Flask):
log = create_logger(app)
with app.app_context():
"""
Maps every single endpoint for blueprint registered in the main application.
Also shows methos available for each endpoint
"""
log.info('MAP ROUTER')
bps = app.blueprints
for bp in bps:
print('', end='\n')
log.info(f'BLUEPRINT RULES: "{bp}"')
for ep in app.url_map.iter_rules():
bp_name = ep.endpoint.split('.')[0]
if bp_name == bp:
log.debug(f'Endpoint: {ep} methods={ep.methods}')
以下是一个函数的示例,该函数仅采用您需要从中获取其 url_map 的蓝图的名称:
def log_blueprint_urls(app: Flask, bp_name: str):
log = create_logger(app)
with app.app_context():
"""
Maps every single endpoint for an specific blueprint in the main application.
Also shows methos available for each endpoint
"""
bps = app.blueprints
if bp_name in bps:
log.info(f'MAP ROUTER FOR BLUEPRINT "{bp_name}"')
for ep in app.url_map.iter_rules():
bp_name = ep.endpoint.split('.')[0]
if bp_name == bp_name:
log.debug(f'Endpoint: {ep} methods={ep.methods}')
else:
log.critical(
f'BLUEPRINT "{bp_name}" has not registered in main application')