2、flask第二站-请求与相应

1、HTTP方法

HTTP (与 Web 应用会话的协议)有许多不同的访问 URL 方法。默认情况下,路由只回应 GET 请
求,但是通过 route() 装饰器传递 methods 参数可以改变这个行为。

一些常用的HTTP方法

1、GRT

浏览器告知服务器:只 获取 页面上的信息并发给我。这是最常用的方法。

2、HEAD

浏览器告诉服务器:欲获取信息,但是只关心 消息头 。应用应像处理 GET 请求一样来处
理它,但是不分发实际内容。在 Flask 中你完全无需人工干预,底层的 Werkzeug 库已经
替你打点好了。

3、POST

浏览器告诉服务器:想在 URL 上 发布 新信息。并且,服务器必须确保 数据已存储且仅存
储一次。这是 HTML 表单通常发送数据到服务器的方法。

4、PUT

类似 POST 但是服务器可能触发了存储过程多次,多次覆盖掉旧值。你可 能会问这有什么
用,当然这是有原因的。考虑到传输中连接可能会丢失,在 这种 情况下浏览器和服务器之
间的系统可能安全地第二次接收请求,而 不破坏其它东西。因为 POST它只触发一次,所以
用 POST 是不可能的。

5、DELETE

删除给定位置的信息。

6、OPTIONS

给客户端提供一个敏捷的途径来弄清这个 URL 支持哪些 HTTP 方法。 从 Flask 0.6 开
始,实现了自动处理。

什么时候GET,什么时候选择POST呢?
GET是获取内容,POST是提交内容。
当浏览器用GET来提交内容时,也能实现,但是会出现问题
首先是GET限制传递的数据内容大小
其次GET提交时,提交的内容会在地址栏显示出来,并不安全

2、程序和请求上下文

Flask 从客户端收到请求时,要让视图函数能访问一些对象,这样才能处理请求。

Flask 使用上下文临时把某些对象变为全局可访问。例如请求对象封装了客户端发送的 HTTP 请求。

from flask import request
@app.route('/useragent/')
def userAgent():
user_agent = request.headers.get('User-Agent')
#headers.get获取浏览器请求的头部,
user:用户 Agent(代理),浏览器此时就是用户的代理。
return '

Your browser is %s

' % user_agent #把获取的内容再返回到页面

3、响应

Flask 调用视图函数后,会将其返回值作为响应的内容。大多数情况下,响应就是一个简单的字符
串,作为 HTML 页面回送客户端。
但 HTTP 协议需要的不仅是作为请求响应的字符串。 HTTP 响应中一个很重要的部分是状态码,
Flask 默认设为 200,这个代码表明请求已经被成功处理。
如果视图函数返回的响应需要使用不同的状态码, 那么可以把数字代码作为第二个返回值,添加到响
应文本之后。

1、下述视图函数返回一个 400 状态码,表示请求无效:

@app.route('/')
def index():
return '

Bad Request

', 400

2、Flask视图函数还可以返回Response对象

from flask import make_response
@app.route('/response/')
def response():
resp = make_response('

Bad Request

',400) return resp

总结:响应的两种方法

1. 视图函数直接返回一个元组 (response, status, headers)
2. 视图函数返回一个make_resonse()函数产生的响应对象

4、Cookies

cookies的操作:

  1. 通过请求对象的 cookies 属性来访问 Cookies。(请求对象的 cookies 属性是一个内容为客户端
    提交的所有 Cookies 的字典。)
  1. 通过响应对象的set_cookie方法来设置 Cookies。
@app.route('/response/')
def resp():
    res = make_response('

Bad request

',400) res.set_cookie('name1','123456') #这里就是说的第一种方法 print request.cookies.get('name1') 这里用的get就是上面说的第二种方法 return res

你可能感兴趣的:(2、flask第二站-请求与相应)