2017-11-22 5 views
0

Ich muss meinen Autorisierungscode für Inhaber Token in Google API Service austauschen. Es gibt eine nette Anwendung namens OauthPlayground, die den Oauth2-Fluss beschreibt. Für Token tauschen sie Anfrage wie folgt verwendet:Angular Exchangeaccess Token für Inhaber Token Oauth2

POST /oauth2/v4/token HTTP/1.1 
Host: www.googleapis.com 
Content-length: 233 
content-type: application/x-www-form-urlencoded 
user-agent: google-oauth-playground 

code=4%2F6RMgcR3WKuY8_bIaZa0o8P6xfxMKZh1f6AZmh9Q-h6Y&redirect_uri=https%3A%2F%2Fdevelopers.google.com%2Foauthplayground&client_id=407408718192.apps.googleusercontent.com&client_secret=************&scope=&grant_type=authorization_code 

Ich habe meine Bewerbung bei Google developer console registriert und meine eigene client_id und client_secret haben. Mein Code, der nicht Werke tut, ist unter:

tryGetBearers(){ 
    let connString='www.googleapis.com/oauth2/v4/token'; 
    let connBody='code='+this.accessToken; 
    connBody+='&redirect_uri='+this.redirect_uri 
    connBody+='&client_id='+this.client_id 
    connBody+='&client_secret='+this.client_secret 
    connBody+='&scope=&grant_type=authorization_code' 

let headers = new Headers(); 
headers.append('content-type', 'application/x-www-form-urlencoded'); 
    this.http.post(connString,connBody,{headers:headers}).subscribe(
     res=>{console.log(res);}, 
     (error)=>{console.log(error); 
     } 
    ); 
    } 

Das Beispiel Körper mit Anfrage gesendet wird:

code=4/Q5p52c8zMfwzAKErog-7QUJzv7aYGyAlCDz_5KE0Mgw&redirect_uri=http://localhost:4200&client_id=665991054229-jmd9i1ovcohglkrlbu1ff1nih9j1cqia.apps.googleusercontent.com&client_secret=hnrh1eGPKFmdEWkdWna7zs6K&scope=&grant_type=authorization_code 

Die Antwort der Funktion nur 404 nicht gefunden wird. Ich habe keine Ahnung, was los ist.

Antwort

0

Ich habe festgestellt, dass die URL schlecht ist. Statt

let connString='www.googleapis.com/oauth2/v4/token'; 

diese Verwendung ist ok:

let connString='https://accounts.google.com/o/oauth2/token'