Angular IO 与 Laravel Lumen PHP API CORS 问题

Posted

技术标签:

【中文标题】Angular IO 与 Laravel Lumen PHP API CORS 问题【英文标题】:Angular IO with Laravel Lumen PHP API CORS issue 【发布时间】:2020-07-21 00:59:46 【问题描述】:

我使用 Laravel Lumen 作为 php REST 服务 API,与 Angular IO 应用程序集成。从 Postman 测试端点,效果很好。当使用暂存实时域并尝试将端点从 Angular 应用程序调用到 API 时,我得到了 CORS 错误,尽管标头是从 Lumen 端使用中间件类设置的。

Cross-Origin Request Blocked: The Same Origin Policy disallows reading the remote resource at http://sub-domain.ext (Reason: CORS header ‘Access-Control-Allow-Origin’ missing)

Cross-Origin Request Blocked: The Same Origin Policy disallows reading the remote resource at http://api.sub-domain.ext. (Reason: CORS request did not succeed).

Access to XMLHttpRequest at 'http://api.sub-domain.ext' from origin 'http://sub-domain.ext' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.

CORS 标头已使用以下中间件从 Lumen 设置:

//Http/Middleware/CorsMiddleware.php

class CorsMiddleware

    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @return mixed
     */
    public function handle($request, Closure $next)
    
        return $next($request)
            ->header('Access-Control-Allow-Origin', '*')
            ->header('Access-Control-Allow-Methods', 'GET, POST, DELETE, OPTIONS')
            ->header('Access-Control-Allow-Headers', 'Origin, Content-Type, Authorization, X-Requested-With');        
    


//bootstrap/app.php

 $app->middleware([
     App\Http\Middleware\CorsMiddleware::class
 ]);

当直接从浏览器点击端点时,没有错误并且输出正确呈现。但是当从实时域/子域(外部)进行调用时,我得到了 CORS 错误。

不确定是否可以从 Angular 端设置任何东西(不使用 ExpressJS),或者它肯定只是服务器端的问题。

感谢您的建议。

【问题讨论】:

在访问暂存域时,您是否还在使用 Postman 或其他浏览器? @GeorgeKoniaris 是的。实际上两者都是。集成后,我使用登台实时服务器。 你在 Laravel 前面使用了某种代理吗?也许登台代理没有将标头传递给客户端。 @GeorgeKoniaris 在 Laravel Lumen 前没有使用代理,使用 AWS Elastic BeansTalk 实例和 Apache 和 PHP 7 作为 API。 【参考方案1】:

问题肯定来自 Laravel 方面,在 .htaccess 文件中,

# Redirect Trailing Slashes If Not A Folder..

如果不是文件夹,它不接受端点末尾的“/”,即<URL/URI>/?Query_Parameters应该是<URL/URI>?Query_Parameters

【讨论】:

以上是关于Angular IO 与 Laravel Lumen PHP API CORS 问题的主要内容,如果未能解决你的问题,请参考以下文章

身份验证中的 Laravel Angular CORS 问题

如何将 Laravel 5.4 与 Angular 4 集成

Laravel 5 CORS 问题与 Ionic Angular

如何将 Angular js 路由与 laravel/lumen 路由一起使用?

Angular JS 与 Laravel - 如何绑定 Eloquent ORM 数组以查看

Lumen 时区设置