03.Response响应对象

Request(请求)是由客户端发出的,Response(响应是由服务端发出的),从宏观上讲响应是由服务器发出的。具体到代码细节上,响应对象是由Flask框架中的视图函数返回的

app.route('/')
def home():
    return "hello"

@app.route('/req/')
def req():
    return render_template('req.html')

这两段代码中分别返回了一个字符串和一个网页,但不管返回什么,本质上都是由服务器返回的一个响应(response)。尽管第一段代码只是一个简单的字符串,但它也做了一个内部的封装,封装的类型为flask命名空间下的Response类。Response类不需要我们手动去构造,它被框架自动执行。

Response的API

来源flask.Response
Response同样包含一个构造函数,其中包含一些内容。
服务器返回包含的一些头部信息:headers
用来表示返回状态的字符串状态文本:status
整型状态码:status_code
响应类型:mimetype(text/html, application/json, text/plain)

构造响应实例 make_response()

使用flask框架中提供的这个函数可以更方便的构造响应实例。

@app.route('/')
def home():
    rsp = make_response("hello")
    return rsp

将上面代码改造一下,就可以返回创建的响应实例。这样做的好处是可以在返回响应的时候添加一些信息,比如我们可以添加一些headers信息。

@app.route('/')
def home():
    rsp = make_response("hello")
    rsp.headers['X-Value'] = "dkljfa34231#!@"
    return rsp

与上述类似,网页也可以通过make_response来返回

@app.route('/req/')
def req():
    rsp = make_response(render_template('req.html'))
    return rsp

还可以通过返回元组来指定更多的返回信息

@app.route('/')
def home():
    rsp = make_response("hello")
    return (rsp, 200, {'X-Value' : ' #$!#$!FDAfda'})    #可以任意修改状态码,也可以指定headers信息

返回响应是由视图函数来完成,如果类型正确的话视图函数会自动将我们的结果包装为响应。如果返回tuple(元组)的话可以指定其他返回信息,rsp, status, headers。
视图函数看起来像普通的函数,但是经过route装饰器匹配规则后就变为视图函数,视图函数总是返回响应对象。

总结:

视图函数是用来返回响应对象的,它的类型是通过flask下的Response类来描述。构造的时候可以通过make_response函数来返回,而不需要通过Response类的构造函数。
返回结果的时候可以通过结果的返回类型,是单个值或者是元组,来决定我们返回的类型结果中包含哪些额外信息。

你可能感兴趣的:(03.Response响应对象)