如何为每个函数调用使用带有 Flask-RESTPlus 的装饰器?
How to use Decorators with Flask-RESTPlus for each function call?
我在向 Resource
应用装饰器时遇到问题。 Api
decorators
参数应用于每个资源函数,或者我必须如何理解 decorators
参数?我的装饰器只在启动时应用,而不是在每次函数调用时应用。我做错了什么?
from flask import Flask, Blueprint
from flask.ext.restplus import Api, Resource, fields
app = Flask(__name__)
def my_decorator(input):
print("my decorator")
return input
api_blueprint = Blueprint('index', __name__, url_prefix='/0')
api = Api(api_blueprint, version='0.1.0', title='Index API',
description='The Index API helps to find things faster in the own database',
# ui=False,
decorators=[my_decorator]
)
app.register_blueprint(api_blueprint)
ns = api.namespace('index', description='Index API')
search_id_score_model = api.model('id', {
'id': fields.String(required=True),
'score': fields.Float(required=True)
})
search_result_model = api.model('result', {
'key': fields.String(required=True),
'ids': fields.List(fields.Nested(search_id_score_model, required=True), required=True)
})
@ns.route('/search/<string:query>')
class Search(Resource):
'''Serach'''
@api.marshal_list_with(search_result_model)
@my_decorator
def get(self, query):
'''fetch result by query'''
return None
if __name__ == '__main__':
app.run(debug=True)
有两个装饰器级别:API-范围和资源范围。
Api.decorators 参数允许将装饰器应用于所有资源,而 Resource.method_decorators 将应用于给定资源的所有方法。
你的问题是你的装饰器只在应用一次而不是一次调用时调用打印。
你应该像这样修改你的装饰器:
def my_decorator(func):
def wrapper(*args, **kwargs):
print("my decorator")
return func(*args, **kwargs)
wrapper.__doc__ = func.__doc__
wrapper.__name__ = func.__name__
return wrapper
注意 __doc__
和 __name__
的矫揉造作。第一个允许正确提取描述,__name__
允许避免自动命名冲突。如果您手动为每个资源指定端点,名称 是可选的。
我在向 Resource
应用装饰器时遇到问题。 Api
decorators
参数应用于每个资源函数,或者我必须如何理解 decorators
参数?我的装饰器只在启动时应用,而不是在每次函数调用时应用。我做错了什么?
from flask import Flask, Blueprint
from flask.ext.restplus import Api, Resource, fields
app = Flask(__name__)
def my_decorator(input):
print("my decorator")
return input
api_blueprint = Blueprint('index', __name__, url_prefix='/0')
api = Api(api_blueprint, version='0.1.0', title='Index API',
description='The Index API helps to find things faster in the own database',
# ui=False,
decorators=[my_decorator]
)
app.register_blueprint(api_blueprint)
ns = api.namespace('index', description='Index API')
search_id_score_model = api.model('id', {
'id': fields.String(required=True),
'score': fields.Float(required=True)
})
search_result_model = api.model('result', {
'key': fields.String(required=True),
'ids': fields.List(fields.Nested(search_id_score_model, required=True), required=True)
})
@ns.route('/search/<string:query>')
class Search(Resource):
'''Serach'''
@api.marshal_list_with(search_result_model)
@my_decorator
def get(self, query):
'''fetch result by query'''
return None
if __name__ == '__main__':
app.run(debug=True)
有两个装饰器级别:API-范围和资源范围。
Api.decorators 参数允许将装饰器应用于所有资源,而 Resource.method_decorators 将应用于给定资源的所有方法。
你的问题是你的装饰器只在应用一次而不是一次调用时调用打印。 你应该像这样修改你的装饰器:
def my_decorator(func):
def wrapper(*args, **kwargs):
print("my decorator")
return func(*args, **kwargs)
wrapper.__doc__ = func.__doc__
wrapper.__name__ = func.__name__
return wrapper
注意 __doc__
和 __name__
的矫揉造作。第一个允许正确提取描述,__name__
允许避免自动命名冲突。如果您手动为每个资源指定端点,名称 是可选的。