预检请求(Preflight Request)是CORS(Cross-Origin Resource Sharing,跨域资源共享)机制中的一种特殊类型的HTTP请求,用于在实际的请求之前询问服务器是否允许跨域请求。以下是预检请求的详细过程:
触发条件:
- 当浏览器检测到一个请求可能会违反同源策略时,比如使用了非CORS安全的方法(如PUT、DELETE等),或者请求中包含了自定义的HTTP头信息,浏览器会自动发送一个预检请求。
请求类型:
- 预检请求是一个HTTP OPTIONS方法的请求。
请求头信息:
- 预检请求会包含
Access-Control-Request-Method
头,指明实际请求将要使用的HTTP方法。 - 如果实际请求中包含了自定义的HTTP头信息,预检请求还会包含
Access-Control-Request-Headers
头,列出所有自定义的头信息名称。
- 预检请求会包含
服务器响应:
- 服务器接收到预检请求后,需要决定是否允许跨域请求。如果允许,服务器的响应中应包含:
Access-Control-Allow-Origin
:指定允许访问资源的源,可以是具体的域名,也可以是通配符*
(但不推荐使用,因为它可能会带来安全风险)。Access-Control-Allow-Methods
:列出允许的HTTP方法。Access-Control-Allow-Headers
:如果请求中包含自定义头信息,这里需要列出这些头信息的名称。
- 服务器还可以设置
Access-Control-Max-Age
头,用来指定预检请求的缓存时间,这样在这段时间内,浏览器不会再次发送预检请求。
- 服务器接收到预检请求后,需要决定是否允许跨域请求。如果允许,服务器的响应中应包含:
浏览器处理预检请求的响应:
- 浏览器检查预检请求的响应,如果服务器允许跨域请求,并且响应中的头信息符合要求,浏览器将发送实际的请求。
- 如果服务器的响应不允许跨域请求,或者响应中的头信息不符合要求,浏览器将阻止实际的请求。
发送实际请求:
- 如果预检请求得到批准,浏览器会发送实际的请求,该请求会包含之前在预检请求中询问的自定义头信息。
预检请求的机制确保了服务器在处理实际请求之前有机会检查并决定是否允许跨域请求,从而增强了Web应用的安全性。