Files
swiftadmin/app/common/middleware/AccessCross.php

32 lines
1.1 KiB
PHP
Raw Normal View History

2022-08-19 19:48:37 +08:00
<?php
namespace app\common\middleware;
use Webman\MiddlewareInterface;
use Webman\Http\Response;
use Webman\Http\Request;
/**
* 全局跨域中间件
* @package app\common\middleware
* @author meystack
*/
class AccessCross implements MiddlewareInterface
{
public function process(Request $request, callable $handler) : Response
{
$response = $request->method() == 'OPTIONS' ? response('') : $handler($request);
$header = [
'Access-Control-Allow-Credentials' => 'true',
'Access-Control-Max-Age' => 1800,
'Access-Control-Allow-Methods' => 'GET, POST, PATCH, PUT, DELETE, OPTIONS',
'Access-Control-Allow-Headers' => 'Authorization, Content-Type, If-Match, If-Modified-Since, If-None-Match, If-Unmodified-Since, X-CSRF-TOKEN, X-Requested-With',
];
$domains = array_merge(config('app.cors_domain'), [request()->host(true)]);
2022-08-20 17:05:05 +08:00
$domains = array_unique($domains);
// 默认为全部允许跨域
$header['Access-Control-Allow-Origin'] = $request->header('Origin', '*');
2022-08-19 19:48:37 +08:00
$response->withHeaders($header);
return $response;
}
}