2

我正在尝试使用 OAuth 对用户进行身份验证并检索用户数据。当用户未登录 twitter 时,身份验证有效,我能够获取用户详细信息。但是,如果用户已经在 Twitter 上登录,我会收到此错误消息“403 Forbidden:服务器理解请求,但拒绝执行它。” . 在一些帖子中,他们说通过 https 而不是 http 发出所有请求。我已经做到了。我已经从 'http://net.tutsplus.com/tutorials/php/how-to-authenticate-users-with-twitter-oauth/' 下载了验证代码。请帮忙。

$twitterOauthObj    =   new TwitterOAuth($oauth_consumer_key, $oauth_consumer_secret);
if(!isset($_GET['oauth_token'])){

    $requestTokenArray  =   $twitterOauthObj->getRequestToken($callback_url);
    $requestToken       =   $requestTokenArray['oauth_token'];
    $tokenSecret        =   $requestTokenArray['oauth_token_secret'];

    $authorizeUrl       =   $twitterOauthObj->getAuthorizeURL($requestToken);
    $response       =   $twitterOauthObj->oAuthRequest($authorizeUrl, 'GET', $requestTokenArray);
    print_r($response);
} else{

    $oauthToken     =   $_GET['oauth_token'];
    $requestToken       =   $oauthToken;
    $oauthVerifier      =   $_GET['oauth_verifier'];
    $accessTokenArray   =   $twitterOauthObj->getAccessToken($oauthVerifier, $oauthToken);
        $oauthToken     =   $accessTokenArray['oauth_token'];
    $oauthTokenSecret   =   $accessTokenArray['oauth_token_secret'];
    $userTwitterId      =   $accessTokenArray['user_id'];
    $screenName     =   $accessTokenArray['screen_name'];
 }
4

1 回答 1

3

行。我让它工作了。我没有重定向以正确授权 url。这是修改后的代码。

if(!isset($_GET['oauth_token'])){

    $requestToken   =   $twitterOauthObj->getRequestToken();
    $_SESSION["oauth_token"] = $requestToken["oauth_token"];
    $_SESSION["oauth_token_secret"] = $requestToken["oauth_token_secret"];

    header("Location:".$twitterOauthObj->getAuthorizeURL($requestToken["oauth_token"]));

}

谢谢你们所有的宝贵建议。真的很感激!!

于 2012-08-09T14:06:13.363 回答