【发布时间】:2013-01-08 06:31:44
【问题描述】:
我正在使用 Twitter 将用户登录到一个网站,在我尝试获取有效的访问令牌之前,该网站似乎正在运行。
require("twitteroauth.php");
require 'twconfig.php';
session_start();
$twitteroauth = new TwitterOAuth(YOUR_CONSUMER_KEY, YOUR_CONSUMER_SECRET);
$request_token = $twitteroauth->getRequestToken('http://****/tw_response.php');
$oauth_token = $request_token['oauth_token'];
$_SESSION['oauth_token'] = $oauth_token;
$oauth_token_secret = $request_token['oauth_token_secret'];
$_SESSION['oauth_token_secret'] = $oauth_token_secret;
if ($twitteroauth->http_code == 200) {
url = $twitteroauth->getAuthorizeURL($request_token['oauth_token']);
header('Location: '.$url);
} else {
die('Something wrong happened.');
}
这似乎工作正常,将我重定向到 twitter 以登录并确认访问,然后将我返回到 tw_response.php(我的回调 url),在 url 中有以下变量:
http://example.com/login.php?oauth_token=sO3X...yj0k&oauth_verifier=Ip6T...gALQ
然后我在 tw_response.php 中尝试获取访问令牌,但它报告为无效。我尝试使用var_dump查看访问令牌的内容如下:
require("twitteroauth.php");
require 'twconfig.php';
session_start();
$oauth_verifier = $_REQUEST['oauth_verifier'];
$oauth_token = $_SESSION['oauth_token'];
$oauth_token_secret = $_SESSION['oauth_token_secret'];
$twitteroauth = new TwitterOAuth(YOUR_CONSUMER_KEY, YOUR_CONSUMER_SECRET, $oauth_token, $oauth_token_secret);
$access_token = $twitteroauth->getAccessToken($data['oauth_verifier']);
var_dump($access_token);
var_dump 的结果以“invalid / expired Token”结尾:
array(8) {
["oauth_url"] => string(104) ""1.0" encoding="UTF-8"?>/oauth/access_token?oauth_consumer_key=ceE...9Dg"
["oauth_nonce"]=> string(32) "c52...d07"
["oauth_signature"]=> string(28) "ry7...Fcc="
["oauth_signature_method"]=> string(9) "HMAC-SHA1"
["oauth_timestamp"]=> string(10) "1359031586"
["oauth_token"]=> string(40) "sO3...j0k"
["oauth_verifier"]=> string(43) "Ip6...ALQ"
["oauth_version"]=> string(63) "1.0 Invalid / expired Token "
}
【问题讨论】:
-
这是在使用 Abraham Williams 的库吗?似乎
getAccessToken(code)仅在您调用的页面为用户提供允许访问后输入的代码时才有效。我认为您在使用回调 URL 时需要同时使用这两条信息。 -
如果您使用有效的回调 URL,则无需使用您的凭据验证
oauth_verifier。无论如何都要检查一下。 -
你的服务器时钟运行正常吗?
-
我觉得这个链接可以帮到你phpgang.com/twitter-oauth-in-php_175.html
标签: php twitter token twitter-oauth