所以我嘗試稍微玩一下前端和後端。當(dāng)嘗試從前端將資料發(fā)送到伺服器時(shí),我得到了
從來(lái)源「http://localhost:3000」存取「http://test.localhost/login」處的XMLHttpRequest 已被CORS 政策阻止:對(duì)預(yù)檢請(qǐng)求的回應(yīng)未透過(guò)存取控制檢查:否「 Access -Control-Allow-Origin'標(biāo)頭存在於請(qǐng)求的資源上。
以下是我的 axios onClick 設(shè)定:
export const login = (email, password) => { return axiosClient.post('/login', { email, password }) .then(response => { // handle successful login return response.data; }) .catch(error => { // handle failed login throw error; }); };
我的 axiosClient 是:
import axios from "axios"; const axiosClient = axios.create({ baseURL: process.env.REACT_APP_API_URL, (my localhost) headers: { 'Content-Type': 'application/json', Accept: 'application/json', }, }); export default axiosClient;
我在後端的cors配置是
<?php namespace App\Http\Middleware; use Closure; use Illuminate\Http\Request; class Cors { /** * Handle an incoming request. * * @param \Illuminate\Http\Request $request * @param \Closure(\Illuminate\Http\Request): (\Illuminate\Http\Response|\Illuminate\Http\RedirectResponse) $next * @return \Illuminate\Http\Response|\Illuminate\Http\RedirectResponse */ public function handle($request, Closure $next) { $headers = [ 'Access-Control-Allow-Origin' => 'http://localhost:3000', 'Access-Control-Allow-Methods' => 'GET, POST, PUT, DELETE, OPTIONS', 'Access-Control-Allow-Headers' => 'Content-Type, Authorization', ]; if ($request->isMethod('OPTIONS')) { return response()->json([], 200, $headers); } $response = $next($request); foreach ($headers as $key => $value) { $response->header($key, $value); } return $response; } }
您是否嘗試過(guò)像這樣將本機(jī)主機(jī) IP 包含在 cors.php 中?
'allowed_origins' => ["http://localhost:3000"]
如果這不起作用,請(qǐng)嘗試使用此配置
'paths' => ['api/*', 'sanctum/csrf-cookie'], 'allowed_methods' => ['*'], 'allowed_origins' => ['*'], 'allowed_origins_patterns' => ["*"], 'allowed_headers' => ['*'], 'exposed_headers' => ["*"], 'max_age' => 0, 'supports_credentials' => false,
並在 Kernel.php 中註釋此行,但請(qǐng)注意此配置將接受來(lái)自任何地方的請(qǐng)求,因此在部署之前確保您的後端接收來(lái)自您首選允許來(lái)源的請(qǐng)求。
\Laravel\Sanctum\Http\Middleware\EnsureFrontendRequestsAreStateful::class