Node JS - 构建OAuth2请求

时间:2016-05-12 12:49:45

标签: javascript node.js express box-api box

我正在尝试为Box API构建OAuth2请求。他们作为指南提供的示例POST请求对我来说有点模棱两可,因为我最近正在学习后端开发。示例如下:

var boxHeaders = {
  'Content-Type': 'application/x-www-form-urlencoded'
};

var boxOptions = {
  url: 'https://api.box.com/oauth2/token',
  method: 'POST',
  headers: boxHeaders,
  form: {
    'grant_type': 'urn:ietf:params:oauth:grant-type:jwt-bearer',
    'assertion': boxtoken,
    'client_id': 'myclientid',
    'client_secret': 'myclientsecret'
  }
};

request.post(boxOptions, function(err, response, body) {
  console.log(body);
});

官方文件: https://box-content.readme.io/docs/app-auth

我尝试这样做的方式如下:

{
  "error":"invalid_request",
  "error_description":"Invalid grant_type parameter or parameter missing"
}

我收到以下错误:

table-layout: fixed;

显然授权类型不正确,但我不知道如何根据Box API示例构建字符串。如果有人可以提供帮助,甚至让我接触到一些关于如何做到这一点的好文章或教程,那就太棒了!

谢谢。

1 个答案:

答案 0 :(得分:1)

我自己也在努力解决这个问题。通过将当前在boxOptions.form中拥有的所有内容移动到请求正文中,我能够实现此目的。

例如:

var boxHeaders = {
  'Content-Type': 'application/x-www-form-urlencoded'
};

var boxOptions = {
  url: 'https://api.box.com/oauth2/token',
  method: 'POST',
  headers: boxHeaders
};

var form = {
  grant_type:'urn:ietf:params:oauth:grant-type:jwt-bearer',
  client_id: 'id',
  client_secret: 'secret',
  assertion: boxtoken
};

var request = https.request(boxOptions, function(response) {
  // do stuff
});

request.write(querystring.stringify(form));
request.end();

希望这会有所帮助。不幸的是,我对请求库不太熟悉,无法提供使用它的示例。