对测试用户进行身份验证{“ error_type”:“ OAuthException”,“ code”:400,“ error_message”:“无效的平台应用程序”}

时间:2019-10-21 14:53:16

标签: instagram-api facebook-graph-api-v2.0

我正在尝试通过Instagram基本显示API恢复访问令牌,但是在尝试对测试用户进行身份验证时出现此错误:

{
    "error_type": "OAuthException",
    "code": 400,
    "error_message": "Invalid platform app"
}

我希望看到应用授权屏幕

4 个答案:

答案 0 :(得分:14)

通过正文和x-www-form-urlencoded传递参数可以正常工作,如您在enter image description here下图中所见

答案 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
        }
      */
    })
  }

}