亚伯拉罕威廉姆斯Twitter OAuth 303错误

时间:2011-08-25 05:39:53

标签: php api twitter oauth

编辑: 因为我已经找到了问题所以我很抱歉这个帖子。

以下是发生的事情: 首先,我注意到发送的URL在.com和account / verify_credentials之间缺少“/”。当我更新它时,我收到了404错误。然后我看了一下twitteroauth.php,我发现了最重要的一个:

/* Set up the API root URL. */
public $host = "https://api.twitter.com/1/";
//  public $host = "https://dev.twitter.com";

被评论出来了。我取消评论它,并评论出较低的一个(我猜测它是不是已经不存在或未被使用?)现在它完全正常工作了!

谢谢大家,感谢威廉姆斯先生一个伟大的Oauth图书馆!


我一直在实施亚伯拉罕·威廉姆斯推特OAuth库,到目前为止一直顺利,直到我连接到Twitter后尝试用它做一些事情。那是我获得303 HTTP代码的时候。然后我将我的实现改为他在github网站上实现它的方式,我仍然遇到同样的问题。有没有人知道发生了什么?

apitest.php是问题发生的地方,$ connection变量有一个303 HTTP代码。 redirect.php和callback.php中相应的$ connection变量都返回200.顺便说一句,所有文件都在同一个目录中。

以下是代码:

connect.php(此页面上的HTML有一个转到redirect.php的按钮)

<?php
/**
* @file
* Check if consumer token is set and if so send user to get a request token.
*/

/**
* Exit with an error message if the CONSUMER_KEY or CONSUMER_SECRET is not defined.
*/
require_once('twitconfig.php');
if (CONSUMER_KEY === '' || CONSUMER_SECRET === '') {
  echo 'A consumer key and secret are required.';
  exit();
}

?>

redirect.php

<?php

/* Start session and load library. */
session_start();
require_once('twitteroauth.php');
require_once('twitconfig.php');

/* Build TwitterOAuth object with client credentials. */
$connection = new TwitterOAuth(CONSUMER_KEY, CONSUMER_SECRET);

/* Get temporary credentials. */
$request_token = $connection->getRequestToken(OAUTH_CALLBACK);

/* Save temporary credentials to session. */
$_SESSION['oauth_token'] = $token = $request_token['oauth_token'];
$_SESSION['oauth_token_secret'] = $request_token['oauth_token_secret'];

/* If last connection failed don't display authorization link. */
switch ($connection->http_code) {
  case 200:
    /* Build authorize URL and redirect user to Twitter. */
    $url = $connection->getAuthorizeURL($token);
    header('Location: ' . $url);
    break;
  default:
    /* Show notification if something went wrong. */
    echo 'Could not connect to Twitter. Refresh the page or try again later.';
}

?>

callback.php

<?php

/**
 * @file
 * Take the user when they return from Twitter. Get access tokens.
 * Verify credentials and redirect to based on response from Twitter.
 */

/* Start session and load lib */
session_start();
require_once('twitteroauth.php');
require_once('twitconfig.php');

/* If the oauth_token is old redirect to the connect page. */
if (isset($_REQUEST['oauth_token']) && $_SESSION['oauth_token'] !== $_REQUEST['oauth_token']) {
  $_SESSION['oauth_status'] = 'oldtoken';
  header('Location: ./clearsessions.php');
}

/* Create TwitteroAuth object with app key/secret and token key/secret from default phase */
$connection = new TwitterOAuth(CONSUMER_KEY, CONSUMER_SECRET, $_SESSION['oauth_token'], $_SESSION['oauth_token_secret']);

/* Request access tokens from twitter */
$access_token = $connection->getAccessToken($_REQUEST['oauth_verifier']);

/* Save the access tokens. Normally these would be saved in a database for future use. */
$_SESSION['access_token'] = $access_token;

/* Remove no longer needed request tokens */
unset($_SESSION['oauth_token']);
unset($_SESSION['oauth_token_secret']);


/* If HTTP response is 200 continue otherwise send to connect page to retry */
if (200 == $connection->http_code) {
  /* The user has been verified and the access tokens can be saved for future use */
  $_SESSION['status'] = 'verified';
  header('Location: ./apitest.php');
} else {
  /* Save HTTP status for error dialog on connnect page.*/
  header('Location: ./clearsessions.php');
}

?>

apitest.php(通过print_r看到问题)

<?php

session_start();
require_once('twitteroauth.php');
require_once('twitconfig.php');

if (empty($_SESSION['access_token']) || empty($_SESSION['access_token']['oauth_token']) || empty($_SESSION['access_token']['oauth_token_secret'])) {
    header('Location: ./clearsessions.php');
}

/* Get user access tokens out of the session. */
$access_token = $_SESSION['access_token'];

/* Create a TwitterOauth object with consumer/user tokens. */
$connection = new TwitterOAuth(CONSUMER_KEY, CONSUMER_SECRET, $access_token['oauth_token'], $access_token['oauth_token_secret']);


/* Get logged in user to help with tests. */
$user = $connection->get('account/verify_credentials');

print_r($connection);

print_r($_SESSION);

?>

第一个print语句的输出是:

TwitterOAuth Object ( 
[http_code] => 303 
[url] => https://dev.twitter.comaccount/verify_credentials.json?oauth_consumer_key=UoXXKdfnVHh2fYD8Csw&oauth_nonce=09bc369393a8eab3a1dc36eaa6230b45&oauth_signature=pe5dYtYq%2FvlGb0c%2BnRR%2BQAXI0Ec%3D&oauth_signature_method=HMAC-SHA1&oauth_timestamp=1314249851&oauth_token=351699791-F6stFFk81poF8ooORgLLxaE2cpSdDT2Vr0Tz9yJm&oauth_version=1.0 
[host] => https://dev.twitter.com 
[timeout] => 30 
[connecttimeout] => 30 
[ssl_verifypeer] => 
[format] => json 
[decode_json] => 1 
[http_info] => Array ( [url] => https://dev.twitter.comaccount/verify_credentials.json?oauth_consumer_key=UoXXKdfnVHh2fYD8Csw&oauth_nonce=09bc369393a8eab3a1dc36eaa6230b45&oauth_signature=pe5dYtYq%2FvlGb0c%2BnRR%2BQAXI0Ec%3D&oauth_signature_method=HMAC-SHA1&oauth_timestamp=1314249851&oauth_token=351699791-F6stFFk81poF8ooORgLLxaE2cpSdDT2Vr0Tz9yJm&oauth_version=1.0 
[content_type] => 
[http_code] => 303 
[header_size] => 565 
[request_size] => 401 
[filetime] => -1 
[ssl_verify_result] => 1 
[redirect_count] => 0 
[total_time] => 0.053773 
[namelookup_time] => 0.003355 
[connect_time] => 0.006399 
[pretransfer_time] => 0.047636 
[size_upload] => 0 
[size_download] => 0 
[speed_download] => 0 
[speed_upload] => 0 
[download_content_length] => 0 
[upload_content_length] => 0 
[starttransfer_time] => 0.053629 
[redirect_time] => 0 
[certinfo] => Array ( ) ) 
[useragent] => TwitterOAuth v0.2.0-beta2 
[sha1_method] => OAuthSignatureMethod_HMAC_SHA1 Object ( ) 
[consumer] => OAuthConsumer Object ( [key] => UoXXKdfnVHh2fYD8Csw [secret] => SyKfxRorvUs6THwj5l26TGEkFOCGf1vG86N7PoS97o [callback_url] => ) [token] => OAuthConsumer Object ( [key] => 351699791-F6stFFk81poF8ooORgLLxaE2cpSdDT2Vr0Tz9yJm [secret] => q8fHaTaFvOUL8XKYX89LSgubr2fSl1xHBUAi8MUqIc [callback_url] => ) 

[http_header] => Array ( [location] => http://guide.a.id.opendns.com/?url=dev%2Etwitter%2Ecomaccount%2Fverify%5Fcredentials%2Ejson%3Foauth%5Fconsumer%5Fkey%3DUoXXKdfnVHh2fYD8Csw%26oauth%5Fnonce%3D09bc369393a8eab3a1dc36eaa6230b45%26oauth%5Fsignature%3Dpe5dYtYq%252FvlGb0c%252BnRR%252BQAXI0Ec%253D%26oauth%5Fsignature%5Fmethod%3DHMAC%2DSHA1%26oauth%5Ftimestamp%3D1314249851%26oauth%5Ftoken%3D351699791%2DF6stFFk81poF8ooORgLLxaE2cpSdDT2Vr0Tz9yJm%26oauth%5Fversion%3D1%2E0 
[content_length] => 0 
[connection] => close 
[date] => Thu, 25 Aug 2011 05:24:50 GMT 
[server] => OpenDNS Guide ) ) 

第二个印刷语句的输出是:

Array ( 
[access_token] => Array ( 
[oauth_token] => 351699791-F6stFFk81poF8ooORgLLxaE2cpSdDT2Vr0Tz9yJm 
[oauth_token_secret] => q8fHaTaFvOUL8XKYX89LSgubr2fSl1xHBUAi8MUqIc 
[user_id] => 351699791 
[screen_name] => jibjib21 ) 
[status] => verified ) 

有没有人知道这个303错误发生了什么以及如何解决?任何帮助将不胜感激。谢谢!

1 个答案:

答案 0 :(得分:0)

303响应是重定向。我的猜测是你需要将.json(或你正在使用的任何格式)添加到你请求的URL的末尾。

即。而不是'account / verify_credentials',您需要请求'account / verify_credentials.json'。