预检请求(Preflight Request)

简介: 预检请求(Preflight Request)

预检请求(Preflight Request)是CORS(Cross-Origin Resource Sharing,跨域资源共享)机制中的一种特殊类型的HTTP请求,用于在实际的请求之前询问服务器是否允许跨域请求。以下是预检请求的详细过程:

  1. 触发条件

    • 当浏览器检测到一个请求可能会违反同源策略时,比如使用了非CORS安全的方法(如PUT、DELETE等),或者请求中包含了自定义的HTTP头信息,浏览器会自动发送一个预检请求。
  2. 请求类型

    • 预检请求是一个HTTP OPTIONS方法的请求。
  3. 请求头信息

    • 预检请求会包含Access-Control-Request-Method头,指明实际请求将要使用的HTTP方法。
    • 如果实际请求中包含了自定义的HTTP头信息,预检请求还会包含Access-Control-Request-Headers头,列出所有自定义的头信息名称。
  4. 服务器响应

    • 服务器接收到预检请求后,需要决定是否允许跨域请求。如果允许,服务器的响应中应包含:
      • Access-Control-Allow-Origin:指定允许访问资源的源,可以是具体的域名,也可以是通配符*(但不推荐使用,因为它可能会带来安全风险)。
      • Access-Control-Allow-Methods:列出允许的HTTP方法。
      • Access-Control-Allow-Headers:如果请求中包含自定义头信息,这里需要列出这些头信息的名称。
    • 服务器还可以设置Access-Control-Max-Age头,用来指定预检请求的缓存时间,这样在这段时间内,浏览器不会再次发送预检请求。
  5. 浏览器处理预检请求的响应

    • 浏览器检查预检请求的响应,如果服务器允许跨域请求,并且响应中的头信息符合要求,浏览器将发送实际的请求。
    • 如果服务器的响应不允许跨域请求,或者响应中的头信息不符合要求,浏览器将阻止实际的请求。
  6. 发送实际请求

    • 如果预检请求得到批准,浏览器会发送实际的请求,该请求会包含之前在预检请求中询问的自定义头信息。

预检请求的机制确保了服务器在处理实际请求之前有机会检查并决定是否允许跨域请求,从而增强了Web应用的安全性。

相关文章
|
缓存
POST 为什么会发送两次请求?
POST 为什么会发送两次请求?
1037 0
|
缓存 JSON 前端开发
CORS 详解,终于不用担心跨域问题了
CORS 详解,终于不用担心跨域问题了
8345 1
CORS 详解,终于不用担心跨域问题了
|
22天前
|
弹性计算 负载均衡 关系型数据库
阿里云价格计算器入口链接:一键计算精准报价
阿里云价格计算器入口及使用方法分享。通过阿里云定价页面可快速进入价格计算器,支持云服务器ECS、对象存储OSS、负载均衡SLB等多种云产品,一键计算精准报价,方便用户根据需求选择合适的产品方案。
94 8
启用 ESLint 后 解决格式化文档自动添加分号和双引号问题
启用 ESLint 后 解决格式化文档自动添加分号和双引号问题
1362 0
启用 ESLint 后 解决格式化文档自动添加分号和双引号问题
|
网络协议 Shell Linux
【Shell 命令集合 网络通讯 】Linux 追踪数据包在网络中的路径 traceroute命令 使用指南
【Shell 命令集合 网络通讯 】Linux 追踪数据包在网络中的路径 traceroute命令 使用指南
409 0
|
安全 网络安全 API
python调用openai api报错self._sslobj.do_handshake()OSError: [Errno 0] Error
python调用openai api报错self._sslobj.do_handshake()OSError: [Errno 0] Error
419 1
python调用openai api报错self._sslobj.do_handshake()OSError: [Errno 0] Error
|
JSON 数据格式 开发者
preflight 错误,但服务端告诉你已经设置过了 CORS 信息怎么办
preflight 错误,但服务端告诉你已经设置过了 CORS 信息怎么办
|
安全 API
预检请求:为跨域请求保驾护航(上)
预检请求:为跨域请求保驾护航(上)
|
前端开发 对象存储 数据安全/隐私保护
阿里云前端直传has been blocked by CORS policy: Response to preflight request doesn‘t pass access control
阿里云前端直传has been blocked by CORS policy: Response to preflight request doesn‘t pass access control
1284 2
|
数据采集 缓存 安全
http proxy 协议的工作原理与常见用途
在这篇博客文章中,我们将深入探讨HTTP代理协议的工作原理,揭示它如何在客户端和服务器之间传递HTTP请求和响应,并讨论它在各种应用场景中的常见用途。
http proxy 协议的工作原理与常见用途