当您尝试从另一个域调用某些 API 时,会发生此问题。例如,要将请求从“url1.com”发送到“url2.com”,您必须在托管“url2.com”的服务器上设置 CORS 策略。
因此,每个请求都应从服务器发送诸如 Access-Control-Allow-Origin、Access-Control-Allow-Headers、Access-Control-Allow-Methods 等 CORS 标头。
您可以在此处阅读如何执行此操作
此外,您必须对您的请求启用 OPTIONS 请求(刚刚在每个 OPTION 请求上发送状态代码 200)。这个东西叫做预检请求。您需要为其创建中间件:
$app->add(function (Request $request, Response $response, $next) {
if ($request->getMethod() !== 'OPTIONS' || php_sapi_name() === 'cli') {
return $next($request, $response);
}
$response = $next($request, $response);
$response = $response->withHeader('Access-Control-Allow-Origin', '*');
$response = $response->withHeader('Access-Control-Allow-Methods', '*');
$response = $response->withHeader('Access-Control-Allow-Headers', '*');
return $response;
});
我已经读到过这一点。但我不明白如何配置。我将配置这段代码。是吗?
<?php
use \Psr\Http\Message\ServerRequestInterface as Request;
use \Psr\Http\Message\ResponseInterface as Response;
$app = new \Slim\App;
$app->post('/login', function (Request $request, Response $response, array $args) {
$email = $request->getParam('email_login');
$response->getBody()->write("Hello, $email");
return $response;
});