Запрос перекрестного происхождения при использовании почтового запроса от Ionic к Laravel - PullRequest
0 голосов
/ 29 сентября 2019

Я пытаюсь отправить запрос с моего внешнего интерфейса (Ionic) на мой внутренний сервер Laravel! это возвращает эту ошибку Cors. Я уже создал класс Cors в Laravel и добавил в него routeMiddleware, я также попробовал решение, созданное barryvdh, и оно также не работает. Когда я пытаюсь выполнить запрос методом get, он работает, но при использовании метода post это не тот случай.

вот мой метод дескриптора в классе Cors в laravel:

public function handle($request, Closure $next)
   {
        header("Access-Control-Allow-Origin: *");

       // ALLOW OPTIONS METHOD
       $headers = [
           'Access-Control-Allow-Origin'=> '*',
           'Access-Control-Allow-Methods'=> 'POST, GET, OPTIONS, PUT, DELETE',
           'Access-Control-Allow-Headers'=> 'Content-Type, X-Auth-Token, Origin'
       ];
       if($request->getMethod() == "OPTIONS") {
           // The client-side application can set only headers allowed in Access-Control-Allow-Headers
           return Response::make('OK', 200, $headers);
       }

       $response = $next($request);
       foreach($headers as $key => $value)
           $response->header($key, $value);
       return $response;
   }

массив промежуточного программного обеспечения в Kernel.php

    protected $middleware = [
        \App\Http\Middleware\TrustProxies::class,
        \App\Http\Middleware\CheckForMaintenanceMode::class,
        \Illuminate\Foundation\Http\Middleware\ValidatePostSize::class,
        \App\Http\Middleware\TrimStrings::class,
        \Illuminate\Foundation\Http\Middleware\ConvertEmptyStringsToNull::class,
        \App\Http\Middleware\Cors::class,

    ];

API-часть массива middlewareGroups в Kernel.php

       'api' => [
            'throttle:60,1',
            'bindings',
            \App\Http\Middleware\Cors::class,
        ]

Массив routeMiddleware в Kernel.php

    protected $routeMiddleware = [
        'auth' => \App\Http\Middleware\Authenticate::class,
        'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
        'bindings' => \Illuminate\Routing\Middleware\SubstituteBindings::class,
        'cache.headers' => \Illuminate\Http\Middleware\SetCacheHeaders::class,
        'can' => \Illuminate\Auth\Middleware\Authorize::class,
        'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
        'signed' => \Illuminate\Routing\Middleware\ValidateSignature::class,
        'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,
        'verified' => \Illuminate\Auth\Middleware\EnsureEmailIsVerified::class,
        'jwt.auth' => Tymon\JWTAuth\Http\Middleware\Authenticate::class,
        'jwt.refresh' => Tymon\JWTAuth\Http\Middleware\RefreshToken::class,
        'cors' => \App\Http\Middleware\Cors::class,
    ];

Маршрут, который я пытаюсь вызвать

  Route::post('auth/login', 'ApiController@login');

Здесь код, который я выполняю в ионном

  login(emaill: string, passwordd: string) {
    return this.http.post<any>(      
      `${environment.laravelBackend}/auth/login`,
      { email: emaill, password: passwordd}
    );
  }

Кто-нибудь знает, как я могу сделать эту работу? Заранее спасибо

1 Ответ

0 голосов
/ 30 сентября 2019

может быть 2 решения, попробуйте оба, если первое или второе не работает.

1) Иногда оно не работает из-за версии для разработчика, в которой создан API, и машины, на которой вы настроиливерсия композитора среды отличается. Проверь это. и, если возможно, отправьте свой компьютер и компьютер, на котором разрабатывается api, версия для композитора.

2) Добавьте CORS в файл .htaccess, например,

Header set  Access-Control-Allow-Origin "*"
Header set  Access-Control-Allow-Methods "GET,POST,PUT,DELETE,OPTIONS"
Header set Access-Control-Allow-Credentials "true"
...