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