2016-08-02 28 views
0

vue-Ressource:vue-Ressource: Access-Control-Allow-Origin Fehler

Vue.http.post(API_URL + '/jwt/access_token', credentials, { 
      headers: { 
       'Access-Control-Allow-Origin': true 
      } 
     }).then(response => { 
      console.log(response.data) 
     }, err => reject(err)) 

Mein api richtig mit dem CORS Laravel konfiguriert ist ..

ich diesen Fehler:

XMLHttpRequest cannot load http://finance.app/jwt/access_token. Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost:8080' is therefore not allowed access. 

Anfrage Header:

OPTIONS /jwt/access_token HTTP/1.1 
Host: finance.app 
Connection: keep-alive 
Access-Control-Request-Method: POST 
Origin: http://localhost:8080 
User-Agent: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/52.0.2743.82 Safari/537.36 
Access-Control-Request-Headers: access-control-allow-origin, content-type 
Accept: */* 
Referer: http://localhost:8080/ 
Accept-Encoding: gzip, deflate, sdch 
Accept-Language: pt-BR,pt;q=0.8,en-US;q=0.6,en;q=0.4 

wo ich falsch liege? :(

Dank

+1

Nun, was ist mit den Antwort-Header? – gurghet

+0

Das Problem wurde gelöst. War keine Einstellung in Vue-Ressource, aber ein kleiner Middleware-Konfigurationsfehler in Laravel. Danke. – Giovanne

Antwort

2

ich glaube, Sie Header in Server-Seite wie folgt gesetzt werden sollte (wenn Sie PHP verwenden):

header('Access-Control-Allow-Origin: *'); 
header('Access-Control-Allow-Methods: POST, GET, OPTIONS'); 
header('Access-Control-Allow-Headers: X-HTTP-Method-Override, Content-Type, x-requested-with, Authorization'); 

der Schlüssel ist, Linie 2, Mittel kann POST Zugriff/GET/OPTIONS anfordern

PS Englisch ist Hoffnung nicht meine Muttersprache wäre es

0

Die Lösung hilft, die für mich gearbeitet ist diesen Header zu PHP hinzufügen.

header('Access-Control-Allow-Origin: *'); 
header('Access-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept'); 
header('Access-Control-Allow-Methods: GET, POST, PUT'); 

Und Vue folgende Option, senden Sie Daten an PHP weitergeben müssen:

Vue.http.options.emulateJSON = true