我正在尝试通过Instagram基本显示API恢复访问令牌,但是在尝试对测试用户进行身份验证时出现此错误:
{
"error_type": "OAuthException",
"code": 400,
"error_message": "Invalid platform app"
}
我希望看到应用授权屏幕
答案 0 :(得分:14)
答案 1 :(得分:10)
菲利斯!
设置Instagram应用程序时,应使用平台特定的应用程序ID,而不要使用Facebook上的通用设置。
在您的Facebook应用仪表板中,转到Products > Instagram > Basic Display
,并应看到 Instagram应用ID 。
在您的授权URL中使用它,它应该可以工作。
答案 2 :(得分:3)
我有一个类似的问题,并且能够通过将请求的内容类型设置为application / x-www-form-urlencoded来解决。下面是一个显示如何执行请求的c#示例:
public async Task<UserTokenResponseModel> GetUserToken(string code)
{
var url =
$"https://api.instagram.com/oauth/access_token";
var request = new HttpRequestMessage(HttpMethod.Post, url);
var client = _httpClientFactory.CreateClient();
var requestContent = new List<KeyValuePair<string, string>>();
requestContent.Add(new KeyValuePair<string, string>("client_id", ClientId));
requestContent.Add(new KeyValuePair<string, string>("client_secret", Secret));
requestContent.Add(new KeyValuePair<string, string>("grant_type", "authorization_code"));
requestContent.Add(new KeyValuePair<string, string>("code", code));
requestContent.Add(new KeyValuePair<string, string>("redirect_uri", "https://localhost:44315/instagram/authorizecallback"));
request.Content = new FormUrlEncodedContent(requestContent);
var response = await client.SendAsync(request);
var content = await response.Content.ReadAsStringAsync();
if (!response.IsSuccessStatusCode)
{
throw new Exception(content);
}
return JsonConvert.DeserializeObject<UserTokenResponseModel>(content);
}
答案 3 :(得分:1)
同样在其他答案中也提到过,问题在于表单主体应该以 x-www-form-urlencoded 格式发送。在邮递员中,这对我来说效果很好,但在 angular 中实现同样的效果有点典型。 在这里,发布请求主体必须首先转换为HttpParams格式,然后像这样将其传递给发布请求的'body'参数。
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
}
*/
})
}
}