本文实例讲述了Flask框架响应、调度方法和蓝图操作。分享给大家供大家参考,具体如下:
响应
像现在大部分的互联网应用用的数据传输格式都是JSON,当用户访问一个URL,我们如何通过Flask返回JSON的响应:
普通做法:
1
2
3
|
@app .route( "/" ) def showInfo(): return jsonify({ "name" : "老王" , "age" : 18 }) |
当我们的应用有大量的URL时,我们需要每次都用jsonify转换一下,不免觉得繁琐。此时会有人说,可以定义一个公共方法,将转换都在这个方法中实现就好了。这也不失为一个可行的方法,还有一种方法让Flask自动帮我们做这些工作:
1
2
3
4
5
6
7
8
9
10
11
|
from flask import Response,jsonify class JSONResponse(Response): @classmethod def force_type( cls ,response,environ = None ): if isinstance (response, dict ): response = jsonify(response) return super (JSONResponse, cls ).force_type(response,environ) app.response_class = JSONResponse @app .route( "/" ) def showInfo(): return { "name" : "老王" , "age" : 18 } |
调度方法
flask.views.MethodView
对每个HTTP方法执行不同的函数(映射到对应方法的小写的同名方法上),这对RESTful API尤其有用。
1
2
3
4
5
6
7
|
from flask.views import MethodView class UserAPI(MethodView): def get( self ): return jsonify({ "method" : "get" }) def post( self ): return jsonify({ "method" : "post" }) app.add_url_rule( "/user" ,view_func = UserAPI.as_view( "userview" )) |
当用户使用GET或POST请求http://localhost:5000/user时,会执行UserAPI中相应get,post函数。
蓝图
蓝图实现了应用的模块化,使用蓝图让应用层次清晰,开发者可以更容易的开发和维护项目。蓝图通常作用于相同的URL前缀。比如/user/item、/user/info这样的地址,都以/user开头,那么他们就可以放在一个模块中。看如下例子:
1
2
3
4
5
6
7
8
9
|
### xxx.py from flask import Blueprint user = Blueprint( "user" ,__name__) @user .route( "/info" ) def info(): return "User Info" #######分割线####### from xxx import user app.register_blueprint(user,url_prefix = "/user" ) |
当用户请求http://localhost:5000/user/info时,就会返回”User Info”信息,效果与Django中的include类似。
希望本文所述对大家基于Flask框架的Python程序设计有所帮助。
原文链接:https://blog.csdn.net/y472360651/article/details/77200156