Como mencionado em outra resposta, o problema estava no corpo do formulário, que deveria ser enviado no formato x-www-form-urlencoded . Estava funcionando bem para mim no carteiro, mas implementar o mesmo em angular é um pouco típico. Aqui, o corpo da solicitação de postagem deve primeiro ser convertido no formato HttpParams e depois passar para o parâmetro 'body' da solicitação de postagem como uma string como esta.
import { Injectable } from '@angular/core';
import { HttpClient, HttpHeaders, HttpParams } from '@angular/common/http';
@Injectable({
providedIn: 'root'
})
export class appService {
constructor(private http: HttpClient) { }
public getInstaAccessToken(formData) {
let full_url = "https://api.instagram.com/oauth/access_token";
let body = new HttpParams()
.set("client_id" , "YOUR_CLIENT_ID")
.set("client_secret","YOUR_CLIENT_SECRET")
.set("code","code received from redirect url")
.set("grant_type","authorization_code")
.set("redirect_uri","your redirect uri")
const requestOptions = {
headers: new HttpHeaders().set('Content-Type', 'application/x-www-form-urlencoded')
}
return this.http.post(full_url, body.toString(), requestOptions).subscribe(data=>{
console.log(data);
/*
{
"access_token": "IGQVJ...",
"user_id": 17841405793187218
}
*/
})
}
}