8

在我的flask-restplus API中,我不仅想检查输入数据,就像下面的例子一样

resource_fields = api.model('Resource', {
    'name': fields.String(default = 'string: name', required = True),
    'state': fields.String(default = 'string: state'),
})

@api.route('/my-resource/<id>')
class MyResource(Resource):
    @api.expect(resource_fields, validate=True)
    def post(self):
        ...

必须有 'name' 字段并且可能有 'state' 字段,但还要检查是否没有其他字段(如果发生这种情况会引发错误)。有没有另一个装饰器?我可以通过自定义函数检查输入数据的正确性吗?

4

3 回答 3

4

不要为您的字段使用字典,而是尝试使用RequestParser(flask-restplus 接受此处记录的两者。这样,如果输入数据中存在任何未知字段,您可以调用parser.parse_args(strict=True)which 将引发异常。400 Bad Request

my_resource_parser = api.parser()
my_resource_parser.add_argument('name', type=str, default='string: name', required=True)
my_resource_parser.add_argument('state', type=str, default='string: state')

@api.route('/my-resource/<id>')
class MyResource(Resource):
    def post(self):
        args = my_resource_parser.parse_args(strict=True)
        ...

有关如何将 request_parser 与您的资源一起使用的更多指导,请查看flask-restplus 存储库中的ToDo 示例应用程序。

于 2016-12-20T20:19:48.427 回答
4

这是完成@shiv 的另一个答案。以下代码片段允许您将有效负载记录在 Flask Restplus 生成的 Swagger 文档中。取自有关期望装饰器的文档:

my_resource_parser = api.parser()
my_resource_parser.add_argument('name', type=str, default='string: name', required=True)
my_resource_parser.add_argument('state', type=str, default='string: state')

@api.route('/my-resource/<id>', endpoint='with-parser')
class MyResource(Resource):
    @api.expect(my_resource_parser)
    def post(self):
        args = my_resource_parser.parse_args(strict=True)
        ...
于 2018-08-04T08:56:38.120 回答
2

对于那些想要继续使用 api.model 而不是请求解析器的人,可以迭代您的输入(假设列表)与模型。该模型的行为类似于字典。

from flask_restplus import abort

def check_exact(response_list, model):
    for response_dict in response_list:
        for key in response_dict:
            if key not in model:
                abort(400, "Non-specified fields added", field=key)

...

@ns.expect(my_model, validate=True)
def post(self, token):
    """Add new set of responses
    """
    check_exact(api.payload['responses'], my_model)
    ...
于 2018-12-10T00:17:42.413 回答