PHP oauth for linkedin

时间:2012-03-30 01:14:27

标签: php oauth linkedin

我正在试用来自linkedin的快速入门指南进行oauth身份验证。我已经安装了oauth库。当我运行下面的代码时,// ask for the pin之后我没有得到任何输出。当我执行echo STDIN时,浏览器会实际呈现STDIN而不是STDIN的值。为什么我看不到输入引脚的字段,如quick start guide中的链接所述?

以下是快速入门指南中的代码。我用自己的API替换了API密钥。

<?php

// TODO change these to your API key and secret
define("API_CONSUMER_KEY", "xxxxxxxxxxxx");
define("API_CONSUMER_SECRET", "xxxxxxxxxxxx");

// create a new instance of the OAuth PECL extension class
$oauth = new OAuth(API_CONSUMER_KEY, API_CONSUMER_SECRET);

// get our request token
$api_url = "https://api.linkedin.com/uas/oauth/requestToken";
$rt_info = $oauth->getRequestToken($api_url);

// now set the token so we can get our access token
$oauth->setToken($rt_info["oauth_token"], $rt_info["oauth_token_secret"]);

// instruct on how to authorize the app
print("Please visit this URL:\n\n");
printf("https://www.linkedin.com/uas/oauth/authenticate?oauth_token=%s", $rt_info["oauth_token"]);
print("\n\nIn your browser and then input the numerical code you are provided here: ");

// ask for the pin  
$pin = trim(fgets(STDIN));

// get the access token now that we have the verifier pin
$at_info = $oauth->getAccessToken("https://api.linkedin.com/uas/oauth/accessToken", "", $pin);

// set the access token so we can make authenticated requests
$oauth->setToken($at_info["oauth_token"], $at_info["oauth_token_secret"]);

// do a simple query to make sure our token works
// we fetch our own profile on linkedin. This query will be explained more on later pages
$api_url = "http://api.linkedin.com/v1/people/~";
$oauth->fetch($api_url, null, OAUTH_HTTP_METHOD_GET);

// print_response is just a fancy wrapper around print and is defined later
// or you can look now and see it in the code download
print_response($oauth);

1 个答案:

答案 0 :(得分:5)

我猜你正在运行一个用于终端的PHP脚本(执行php myscript.php 在终端中)在服务器上下文中。并且服务器上下文不允许从中读取 STDIN。

编写一个以$pin = "PIN I got from that URL"开头的新PHP文件 从提供的脚本中运行该脚本。并且,请注意print_response 功能,我不知道他们的意思: - )

在您的示例中,LinkedIn在该网页中显示令牌。这被称为 带访问,对于不做重定向的设备很有用,比如旧智能手机(AFAIK!)。 在常规工作流程中,将其配置为重定向到回调网址 mysite.com/oauth_client/authentication_success?token=TOKEN并留下该网址 处理剩下的事情。