使用 pre-request 优化 Flask 入参校验

在使用Flask实现Restful接口时,需要对请求参数进行校验以判断其是否符合特定的规则。本文将介绍如何通过 pre-request 库优化校验逻辑。

接口需求

假设我们需要实现一个收集用户填写的个人信息的接口,该接口的具体需求如下:

  1. 接口路径: /user/info/new
  2. 接口字段:
字段 类型 说明
userName string 用户昵称,必填,2-20位字符串
gender int 用户性别,必填,1-男 2-女
age int 用户年龄,必填,18-60之间的整数
country string 用户国籍,选填,默认为 中国, 字符串长度为>2

接口实现

如果不借助任何第三方工具实现上述接口的话,代码可能如下所示:

from flask import request, Flask


app = Flask(__name__)


@app.route("/user/info/new", methods=["POST"])
def user_info_handler():
    # 1.判断用户名称参数是否合法
    user_name = request.form.get("userName")
    if not user_name or not isinstance(user_name, str):
        return "请填写正确的用户名称"
    if len(user_name) < 2 or len(user_name) > 20:
        return "用户名称长度不正确"

    # 2.判断用户性别参数是否合法
    gender = request.form.get("gender")
    if not gender:
        return "请填写用户性别"
    try:
        gender = int(gender)
    except ValueError:
        return "用户性别格式不正确"
    if gender not in [1, 2]:
        return "用户性别参数必须在[1, 2]之间"

    # 3.判断用户年级参数是否合法
    age = request.form.get("age")
    if not age:
        return "请填写用户年龄"
    try:
        age = int(age)
    except ValueError:
        return "用户年龄格式不正确"
    if age < 18 or age > 60:
        return "年龄必须在18-60之间"

    # 4.判断国籍是否合法
    country = request.form.get("country", "中国")
    country = str(country)
    if len(country) < 2:
        return "国籍名称长度不合法"
    
    # TODO: 用户信息注册逻辑
    return "Success"


if __name__ == "__main__":
    app.run(port=8080)

正如上面的代码所示,为了保证存储到数据库中的数据符合设计要求,开发人员需要对入参做大量的校验工作,稍有不慎就有可能为系统留下漏洞隐患。

使用 pre-request 校验入参

同样是实现上述的接口需求,我们来看一下通过pre-request如何将大量重复的校验逻辑进行屏蔽。

from flask import Flask
from pre_request import pre, Rule


app = Flask(__name__)


rule = {
    "userName": Rule(type=str, required=True, gte=3, lte=20, dest="user_name"),
    "gender": Rule(type=int, required=True, enum=[1, 2]),
    "age": Rule(type=int, required=True, gte=18, lte=60),
    "country": Rule(type=str, required=False, gte=2, default="中国")
}


@app.route("/user/info/new", methods=["POST"])
def user_info_handler():
    params = pre.parse(rule=rule)
    # TODO: 用户信息注册逻辑
    return "Success"


if __name__ == "__main__":
    app.run(port=8080)

如上方所示,复杂的参数校验工作变成了校验规则的编写,pre.parse 函数会自动捕获请求参数并判断是否符合校验规则,不符合校验规则时会自动生成错误响应,用户不需要做任何处理。

pre-request 相关链接

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,937评论 18 139
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,958评论 6 342
  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 11,150评论 6 13
  • 上一篇《WEB请求处理一:浏览器请求发起处理》,我们讲述了浏览器端请求发起过程,通过DNS域名解析服务器IP,并建...
    七寸知架构阅读 81,227评论 21 356
  • 礼仪之邦的中国,从孩堤及白发苍苍老人,都以身作则的示范文明之邦。但我觉得最奇妙,神奇的词语便是,谢谢!因...
    书_赢阅读 467评论 0 1