如何在没有重定向的情况下获取LinkedIn API访问令牌

时间:2014-11-18 11:21:03

标签: javascript node.js linkedin

我尝试使用LinkedIn的API访问大学的LinkedIn页面,定期收集他们有多少粉丝。这似乎可行,但我似乎无法生成一个访问令牌,而没有一些奇怪的重定向URL,必须带你到GUI登录页面!

我正在使用node.js,特别是此软件包:https://www.npmjs.org/package/node-linkedin

我有一个API密钥和秘密,所以我需要的是一个访问令牌,然后我将设置为实际开始使用他们的API路由。

var Linkedin  = require('node-linkedin')('KEY', 'SECRET', 'callback');
var linkedin = Linkedin.init('my_access_token'); // need a token to initialise!

有什么想法吗?

编辑:到目前为止,这是我的代码:

var Linkedin  = require('node-linkedin')('KEY', 'SECRET', './oauth/linkedin/callback');

app.get('/oauth/linkedin', function(req, res) {
  // This will ask for permisssions etc and redirect to callback url.
  Linkedin.auth.authorize(res, ['r_basicprofile', 'r_fullprofile', 'r_emailaddress', 'r_network', 'r_contactinfo', 'rw_nus', 'rw_groups', 'w_messages']);
});

app.get('/oauth/linkedin/callback', function(req, res) {
  Linkedin.auth.getAccessToken(res, req.query.code, function(err, results) {
    if ( err )
        return console.error(err);

    /**
     * Results have something like:
     * {"expires_in":5184000,"access_token":". . . ."}
     */

    console.log(results);
    var linkedin  = Linkedin.init(result);
    return res.redirect('/');
  });
});

1 个答案:

答案 0 :(得分:3)

您要做的是仅应用程序身份验证,似乎LinkedIn已删除此选项,而不像Facebook和Twitter。从现在开始,它只能作为用户进行身份验证。 如果你真的想跳过重定向,你可以使用像无头浏览器PhantomJS这样的东西。但我强烈建议您不要这样做,因为LinkedIn要求用户在其许可协议中进行身份验证。我不知道它是否合法,但您可以为自己提供一个终点,用于生成authentication_code和access_token,然后将其保存到数据库(默认情况下有效期为60天)。