本文实例讲述了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