为了账号安全,请及时绑定邮箱和手机立即绑定

带有 Laravel Lumen PHP API CORS 问题的 Angular IO

带有 Laravel Lumen PHP API CORS 问题的 Angular IO

PHP
三国纷争 2022-12-11 19:14:48
我使用 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.phpclass 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),或者这绝对只是服务器端问题。谢谢你的建议。
查看完整描述

1 回答

?
守着一只汪

TA贡献1872条经验 获得超3个赞

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

# Redirect Trailing Slashes If Not A Folder..

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


查看完整回答
反对 回复 2022-12-11
  • 1 回答
  • 0 关注
  • 119 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信