我试着跟踪一些问题,但没有运气:
由于outside of context问题,我在一个util.py文件中创建了一个limiter函数,如下所示:
def limiter():
_limiter = Limiter(
app,
key_func=get_remote_address
)
return _limiter在我的烧瓶-Restful资源中,我在method-decorators中调用了这个限制器。
from ..utils import limiter
class UsersView(Resource, CustomAPIMixin):
method_decorators = [limiter().limit("1/minute", methods=["GET"])]
@jwt_authenticate()
def get(self):
user_id = get_jwt_identity()
return self.api_response(content={"user_id": user_id})注意:我在使用Flask version 2和Flask-Limiter 1.4
编辑-1:
my_api
models
scripts
views
users.py
__init__.py # contains create_app() to return Flask app
utils.py. # contains custom rate_limit() function编辑-2:这里是烧瓶限制器不工作的完整代码:
发布于 2021-08-03 21:14:38
瓶限制器文档给出了一个适合这种情况的示例:https://flask-limiter.readthedocs.io/en/stable/#using-flask-pluggable-views。
如果您将decorators设置为method_decorators而不是method_decorators,那么它将修复您的问题。
下面是一个完全工作的示例,它演示了所提供的代码的速率限制。
from flask import Flask
from flask_restful import Resource, Api
from flask_limiter import Limiter
from flask_limiter.util import get_remote_address
app = Flask(__name__)
api = Api(app)
def limiter():
_limiter = Limiter(
app,
key_func=get_remote_address
)
return _limiter
class CustomAPIMixin:
def api_response(self, content):
return content
def get_jwt_identity():
return 0
class UsersView(Resource, CustomAPIMixin):
decorators = [limiter().limit("1/minute", methods=["GET"])]
# @jwt_authenticate()
def get(self):
user_id = get_jwt_identity()
return self.api_response(content={"user_id": user_id})
api.add_resource(UsersView, '/')
if __name__ == '__main__':
app.run(debug=True)https://stackoverflow.com/questions/68524622
复制相似问题