29 lines
1006 B
PHP
29 lines
1006 B
PHP
<?php
|
||
namespace app\middleware;
|
||
|
||
use Webman\Http\Request;
|
||
use Webman\Http\Response;
|
||
use Webman\MiddlewareInterface;
|
||
|
||
class CrossDomain implements MiddlewareInterface
|
||
{
|
||
public function process(Request $request, callable $next): Response
|
||
{
|
||
// 动态允许请求来源(支持携带Cookie)
|
||
$origin = $request->header('origin', '*');
|
||
$response = $next($request);
|
||
|
||
// 设置跨域响应头
|
||
$response->withHeaders([
|
||
'Access-Control-Allow-Origin' => $origin,
|
||
'Access-Control-Allow-Methods' => 'GET, POST, PUT, DELETE, OPTIONS',
|
||
'Access-Control-Allow-Headers' => 'Content-Type, Authorization, X-Requested-With',
|
||
'Access-Control-Allow-Credentials' => 'true', // 允许携带Cookie
|
||
'Access-Control-Max-Age' => 86400, // 预检请求缓存时间(秒)
|
||
'Vary' => 'Origin' // 避免缓存干扰
|
||
]);
|
||
|
||
return $response;
|
||
}
|
||
}
|