目录
一、flask路由分模块管理1.1、使用蓝图1.2、使用flask_restful二、自定义flask_restful响应格式一、flask路由分模块管理
1.1、使用蓝图
在flask中可以使用蓝图Blueprint来进行创建路由进行分模块。 具体操作,我们可以在项目根目录下创建一个controller文件夹来存储分模块的路由。
(资料图)
在controller文件夹里创建product_controller.py,在里面如下写法引入蓝图,并且注册蓝图:
from flask import Blueprint product_blue = Blueprint("product", __name__) # 定义蓝图路径及请求方法和请求返回逻辑 @product_blue.route("/get", methods=["get", "post"]) def getproduct(): return "product" @product_blue.route("/search", methods=["get", "post"]) def searchproduct(): return "search"
那么我们在项目主逻辑文件main.py
中,去引入并注册这个蓝图:
from flask import Flask from controller.product_controller import product_blue app = Flask(__name__) # 商品模块 app.register_blueprint(product_blue, url_prefix="/product") if __name__ == "__main__": app.run()
接下来我们运行程序,可以看到如下效果:
可以看到我们使用蓝图分模块的创建已经生效了,这样如果模块对的话,我们就方便管理了。不会造成代码全部冗余在一个主文件中。
1.2、使用flask_restful
那么相比与蓝图Blueprint,flask_restful的优势就在于它能够做更多的操作,比如参数的验证,返回直接字典就能解析成json
。
首先我们输入命令pip3 install flask_restful
安装flask_restful。 在product_controller中写入如下代码:
from flask_restful import Resource, reqparse class ProductView(Resource): @staticmethod def post(): parse = reqparse.RequestParser() parse.add_argument("product_id", type=str, help="商品id必传", required=True, trim=True) args = parse.parse_args() product_id = args.product_id return { "msg": "商品id是" + product_id, "code": 200 } @staticmethod def get(): return { "msg": "商品", "code": 200 }
那么main.py
主文件中修改如下:
from controller.product_controller import ProductView app = Flask(__name__) api = Api(app) api.add_resource(ProductView, "/product", endpoint="product") if __name__ == "__main__": app.run()
现在已经是restful形式的api了,我们采用apifox或者postman测试请求接口如下:
可以看到get请求成功,但是在post请求时,我们没有传必传参数,所以出现了报错。我们尝试将必传参数加上:
那么可以看到将必传的参数加上后,请求成功。 两种模式可以共存,但是一般我们只用一种就行了。
相信细心的小伙伴已经发现,失败和成功返回的数据格式不一样,成功有code,失败却没有code,那么我想自定义失败返回的数据格式,将怎么操作呢,接下来自定义flask_restful的错误响应。
二、自定义flask_restful响应格式
在根目录下创建errors.py
,写入如下代码:
""" design the custom error response of flask-restful """ from flask_restful import abort def generate_response(msg, status): return { "code": status, "msg": msg, } def custom_abort(http_status_code, *args, **kwargs): if http_status_code == 400: abort(400, **generate_response(msg=[kwargs.get("message")], status=http_status_code)) abort(http_status_code)
我们将错误状态拎出来自定义返回格式。 在main.py
主文件中加入这两行代码:
from errors import custom_abort flask_restful.abort = custom_abort
效果如下:
可以看到我们成功的返回了相同的数据结构。
以上就是flask路由分模块管理及自定义restful响应格式详解的详细内容,更多关于flask路由管理restful响应格式的资料请关注脚本之家其它相关文章!
X 关闭
X 关闭
- 1亚马逊开始大规模推广掌纹支付技术 顾客可使用“挥手付”结账
- 2现代和起亚上半年出口20万辆新能源汽车同比增长30.6%
- 3如何让居民5分钟使用到各种设施?沙特“线性城市”来了
- 4AMD实现连续8个季度的增长 季度营收首次突破60亿美元利润更是翻倍
- 5转转集团发布2022年二季度手机行情报告:二手市场“飘香”
- 6充电宝100Wh等于多少毫安?铁路旅客禁止、限制携带和托运物品目录
- 7好消息!京东与腾讯续签三年战略合作协议 加强技术创新与供应链服务
- 8名创优品拟通过香港IPO全球发售4100万股 全球发售所得款项有什么用处?
- 9亚马逊云科技成立量子网络中心致力解决量子计算领域的挑战
- 10京东绿色建材线上平台上线 新增用户70%来自下沉市场