Http option 请求是怎么回事

 在前后台分离的项目中,经常会遇到浏览器想服务端发送一个post/patch请求,实际上产生了两个请求,一个是Option,另一个才是真实的Post/Patch请求, 而get请求则不会产生Options请求。

 

 造成此种问题的原因是浏览器处理跨域的机制,下面来掰扯一下为什么会出现Option请求。

Options请求出现的情况有两种:

1、获取后台服务器支持的HTTP的通信方式

2、对跨域请求进行preflight request(预检请求)。

预检请求首先需要向另外一个域名的资源发送一个Http Options的请求头,以检测实际发送的请求是否是安全的。options请求是浏览器自发起的preflight request(预检请求)。

 

preflight request请求报文中有两个需要关注的首部字段:

(1)Access-Control-Request-Method:告知服务器实际请求所使用的HTTP方法;

(2)Access-Control-Request-Headers:告知服务器实际请求所携带的自定义首部字段。

同时服务器也会添加origin header,告知服务器实际请求的客户端的地址。服务器基于从预检请求获得的信息来判断,是否接受接下来的实际请求。

服务器所返回的Access-Control-Allow-Methods首部字段将所有允许的请求方法告知客户端,返回将所有Access-Control-Request-Headers首部字段将所有允许的自定义首部字段告知客户端。此外,服务器端可返回Access-Control-Max-Age首部字段,允许浏览器在指定时间内,无需再发送预检请求,直接用本次结果即可。

在我们开发过程中出现的浏览器自发起的options请求就是上面的第二种情况。实际上,跨域请求中的”复杂请求”发出前会进行一次方法是options的preflight request。

二、当跨域请求是简单请求时不会进行preflight request,只有复杂请求才会进行preflight request。

跨域请求分两种:简单请求、复杂请求;

符合以下任一情况的就是复杂请求:

1.使用方法put/delete/patch/post;

2.发送json格式的数据(content-type: application/json)

3.请求中带有自定义头部;

其他情况则可理解为是简单请求。

为什么跨域的复杂请求需要preflight request

复杂请求可能对服务器数据产生副作用。例如delete或者put,都会对服务器数据进行修改,所以在请求之前都要先询问服务器,当前网页所在域名是否在服务器的许可名单中,服务器允许后,浏览器才会发出正式的请求,否则不发送正式请求。

转载于:https://www.cnblogs.com/bradwarden/p/11505999.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Flask 中获取 Option 请求的方式与获取其他类型的请求(如 GET 或 POST)类似。可以使用 `request.method` 属性来判断请求的方法类型,并根据需要进行处理。 下面是一个示例代码,演示了如何在 Flask 中获取 Option 请求: ```python from flask import Flask, request app = Flask(__name__) @app.route('/example', methods=['OPTIONS']) def handle_options_request(): if request.method == 'OPTIONS': # 处理 Option 请求 # 在这里可以设置跨域请求所需的响应头,例如允许的请求方法、头部信息等 response = app.make_default_options_response() response.headers['Access-Control-Allow-Origin'] = '*' response.headers['Access-Control-Allow-Methods'] = 'OPTIONS, GET, POST' response.headers['Access-Control-Allow-Headers'] = 'Content-Type' return response if __name__ == '__main__': app.run() ``` 在上述示例中,我们通过设置路由装饰器 `@app.route('/example', methods=['OPTIONS'])` 来指定处理 Option 请求的路由。 在处理函数 `handle_options_request` 中,我们首先通过 `request.method` 判断请求的方法是否为 Option。如果是 Option 请求,我们可以在此处设置需要的响应头信息,例如允许的请求方法、头部信息等。最后,我们返回一个带有设置好响应头信息的 Response 对象。 注意:上述示例中设置了通配符 `'Access-Control-Allow-Origin': '*'`,这允许来自任何域的请求访问该资源。在实际应用中,可以根据需要设置合适的域名或使用其他跨域请求配置。 希望这个例子对你有帮助!如果你还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值