zl程序教程

您现在的位置是:首页 >  后端

当前栏目

flask_restful 解析请求参数

restful 解析 参数 请求 Flask
2023-09-11 14:14:27 时间

使用 flask_restful 解析请求参数

Rethink 关注
1 字数 1,473 阅读 2,290

资源类必须继承flask_restful.Resource
Python v3.7.0 , flask_restful v0.3.7

基本参数

from flask_restful import reqparse, Resource

class UserInfo(Resource):
def post(self):
parser = reqparse.RequestParser()
parser.add_argument(“method”, help="[method] cannot be converted") # Python3中参数的默认类型为str
parser.add_argument(“parameters”, type=dict, help="[parameters] cannot be converted")
args = parser.parse_args()

  <span class="token keyword">return</span> <span class="token punctuation">{</span><span class="token string">"name"</span><span class="token punctuation">:</span><span class="token string">"Foo"</span><span class="token punctuation">}</span>

如果指定了help 变量的值,那么在解析请求参数时,如果出现了类型错误,那么会将它渲染为错误信息;若未指定help的值,那么默认的行为是返回类型错误信息本身。如下所示:



help中的信息允许包含一个特殊的插入符号{error_msg},它将会替换成类型错误的字符串表示。这种方式能够实现自定义错误消息,同时保留原始的错误消息。如下所示:

from flask_restplus import reqparse

parser = reqparse.RequestParser()
parser.add_argument(
‘foo’,
choices=(‘one’, ‘two’),
help=‘Bad choice: {error_msg}’
)

如果请求中的’foo’参数值为’three’,那么错误信息将会如下所示:

{
“message”: {
“foo”: “Bad choice: three is not a valid choice”,
}
}

在默认情况下,参数不是必需的。并且,如果传入了RequestParser中未声明的参数,则这些参数将会被自动忽略,可以在调用parse_args时传入strict=True,以确保在请求中包含解析器没有定义的参数时抛出错误。

必须参数

若要确保某个参数必需提供,那么可以在调用add_argument()时传入required=True参数项。

parser.add_argument("method",required=True, help="[method] cannot be converted")

此时,如果请求中未提供method参数,那么将会返回help中的错误信息。

参数位置

默认情况下,RequestParser尝试从 flask.Request.values和 flask.Request.json 中解析值。

在 add_argument() 中使用location参数,来指定获取值的其他位置,可以使用 flask.Request 对象上的任何变量,例如:

# 仅在 POST body中查找
parser.add_argument("method", location="form")

仅在querystring中查找

parser.add_argument(“PageSize”, location=“args”)

从请求头中查找

parser.add_argument(“User-Agent”, location=“headers”)

从http cookies中查找

parser.add_argument(“session_id”, location=“cookies”)

从上传文件中查找

parser.add_argument(“picture”, type=werkzeug.datastructures.FileStorage, location=“files”)

Request是flask的请求对象,这个请求对象封装了从客户端发来的请求报文,我们能从其中获取请求报文中的所有数据。Request提供的常用属性和方法如下:

需要注意的是,和普通的字典类型不同,当从request对象的类型为MutliDict或ImmutableMultiDict的属性(比如files、form、args)中直接使用键作为索引获取数据时(比如request.args['name']),如果没有对应的键,那么会返回HTTP 400错误响应(Bad Request,表示请求无效),而不是抛出KeyError异常,为了避免这个错误,我们应该使用get()方法获取数据,如果没有对应的值则返回None;get()方法的第二个参数可以设置默认值。

参数多位置

为location参数赋一个列表就能为参数指定多个位置:

parser.add_argument('text', location=['headers', 'values'])

当指定多个参数位置时,那么所有指定位置的参数将会组成一个MultiDict。其中,列表中最后位置处的参数将会优先存储在结果集中

如果参数位置列表中包含headers位置,那么参数名将变成对大小写敏感,并且必须匹配它们的标题大小写名称(见str.title())。

指定location='headers'(而不是作为列表的某个元素)将保留大小写不敏感的特性。

高级类型处理

有时,我们需要其他原始类型来处理输入验证问题。为此,inputs模块中提供了一些常用的类型处理方法,如下:

  • boolean用于广泛的布尔值处理
  • ipv4和ipv6用于IP地址
  • date_from_iso8601和 datetime_from_iso8601则用于ISO8601 date和datetime处理
from flask_restful import inputs
...

parser.add_argument(“flag”, type=inputs.boolean, help=“The expected field type is a Boolean type”)

解析器继承

很多情况下,我们都需要为不同的资源指定不同的解析器。不过,如果这些不同的解析器之间存在大量相同的字段的话,将会存在大量重复编码的问题。为此,我们可以编写一个父解析器,父解析器中包含所有共同的参数,然后利用copy()方法来扩展解析器。另外,也可以利用replace_argument()来覆写父解析器中的任何参数,或者利用remove_argument()完全移除父解析器中的某个参数。例如:

from flask_restful import Resource, reqparse, inputs

# 父解析器
parser_root = reqparse.RequestParser()
parser_root.add_argument(“author”)

# 解析器继承
parser_index = parser_root.copy()
parser_index,add_argument(“email”) # 子解析器parser_index拥有author和email两个参数

parser_index.replace_argument(‘author’, type=int, required=True, location=‘json’)
# 此时,'author’参数变成了一个必需的int类型的参数,并且查找位置为json;而不再是父解析器中定义的str类型的可选参数

parser_index.remove_argument(‘author’)
# 此时,parser_index中不再包含’author’参数

错误处理

RequestParser处理错误的默认方式是在第一个错误产生时中断。当我们拥有需要花费一定时间来处理的参数时,这种方式是有好处的。然而,通常来说,将所有产生的错误都绑定在一起,然后同时一次性返回给客户端,这种方式则更加友好。这种方式既可以在Flask应用级别指定,也可以在特定的RequestParser实例级别指定。为了调用一个包含错误绑定选项的RequestParser,需要传入参数bundle_errors。例如:

from flask_restplus import reqparse

parser = reqparse.RequestParser(bundle_errors=True)
parser.add_argument(‘foo’, type=int, required=True)
parser.add_argument(‘bar’, type=int, required=True)

如果某个请求中同时不包含’foo’’bar’,那么返回的错误将看起来如下所示:

{
“message”: {
“foo”: “foo error message”,
“bar”: “bar error message”
}
}

默认操作将仅仅返回第一个错误

parser = RequestParser()
parser.add_argument(‘foo’, type=int, required=True)
parser.add_argument(‘bar’, type=int, required=True)

{
“message”: {
“foo”: “foo error message”
}
}

应用级别的配置key为“BUNDLE_ERRORS”。例如:

from flask import Flask

app = Flask(name)
app.config[‘BUNDLE_ERRORS’] = True

警告:BUNDLE_ERRORS是一个全局设置,它将覆盖每个RequestParser实例中的bundle_errors选项值。

除上面介绍的内容之外,add_argument 还支持以下可选参数:

  • default:默认值,如果这个参数没有值,那么将使用这个参数指定的值。
  • choices:选项。提交上来的值只有满足这个选项中的值才符合验证通过,否则验证不通过。
  • trim:是否要去掉前后的空格。

其中的type,可以使用python自带的一些数据类型,也可以使用flask_restful.inputs下的一些特定的数据类型来强制转换。比如一些常用的:

  • url:会判断这个参数的值是否是一个url,如果不是,那么就会抛出异常。
  • regex:正则表达式。
  • date:将这个字符串转换为datetime.date数据类型。如果转换不成功,则会抛出一个异常

原文地址:https://www.cnblogs.com/leejack/p/9164208.htmlHackHan

1人点赞
更多精彩内容,就在简书APP
"小礼物走一走,来简书关注我"
赞赏支持 还没有人赞赏,支持一下
Rethink When we are young, the world is also young.
总资产29 (约1.87元) 共写了5.7W字 获得420个赞 共146个粉丝
关注