flask_restful 解析请求参数

class UserInfo (Resource ):
def post (self ):
parser = reqparse .RequestParser ()
parser .add_argument (“method”, help =”[method] cannot be converted”)
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的值,那么默认的行为是返回类型错误信息本身。如下所示:

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

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

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

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

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

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

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

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

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

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

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参数赋一个列表就能为参数指定多个位置:

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

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

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

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

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

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

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

parser_root = reqparse .RequestParser ()
parser_root .add_argument (“author”)

parser_index = parser_root .copy ()
parser_index ,add_argument (“email”)

parser_index .replace_argument (‘author’, type =int , required =True , location =’json’)

parser_index .remove_argument (‘author’)

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

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

{
“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”。例如:

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数据类型。如果转换不成功,则会抛出一个异常

Original: https://blog.csdn.net/qq_15821487/article/details/115975354
Author: 愚昧之山绝望之谷开悟之坡
Title: flask_restful 解析请求参数

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/750036/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球