2012-10-12 51 views
1

我正在使用亞伯拉罕威廉姆斯的oAuth庫來更新狀態。該應用程序沒有UI(除了來自Twitter的提示信息,而是用戶在瀏覽器中輸入了URL)。 :原因:1「。會話過期了twitter oAuth

我插入了一些測試代碼,看起來好像會話在轉換之間迷路了:$ _SESSION ['tweetmsg']在index.php的初始調用中設置,但是當切換到connect.php發生,它看來,如果會話丟失任何想法

以下是源代碼:?

的index.php

<?php 
include_once '../../winsinclude/tw_config.php'; 
require_once "../../winsinclude/twitteroauth.php"; 
require_once "../../winsinclude/OAuth.php"; 
session_start(); 
if (empty($_SESSION['access_token'])) { 
    $_SESSION['tweetmsg'] = create_tweet_text(); 
    print "<script>self.location='./connect.php');</script>"; 
} 

$connection = new TwitterOAuth(
    CONSUMER_KEY, 
    CONSUMER_SECRET, 
    $_SESSION['access_token']['oauth_token'], 
    $_SESSION['access_token']['oauth_token_secret'] 
); 

if (!isset($_SESSION['tweetmsg'])) { 
    exit('No tweet value in session or from form'); 
} 
$tweetmsg = $_SESSION['tweetmsg']; 
$result = $connection->post('statuses/update', array('status' => $tweetmsg)); 
unset($_SESSION['tweetmsg']); 
if (200 === $connection->http_code) { 
    echo 'Tweet Posted: '.$tweetmsg; 
} 
else { 
    echo 'Could not post Tweet. Error: '.$httpCode.' Reason: '. 
    session_destroy(); 
} 
function create_tweet_text() { 
    return 'this is a test'; 
} 

connect.php

?php 
session_start(); 
include_once '../../winsinclude/tw_config.php'; 
require_once "../../winsinclude/twitteroauth.php"; 
require_once "../../winsinclude/OAuth.php"; 

$connection = new TwitterOAuth(CONSUMER_KEY, CONSUMER_SECRET); 
$request_token = $connection->getRequestToken(OAUTH_CALLBACK.'callback.php'); 

$_SESSION['oauth_token'] = $request_token['oauth_token']; 
$_SESSION['oauth_token_secret'] = $request_token['oauth_token_secret']; 

$url = $connection->getAuthorizeURL($request_token); 
print "<script>self.location='$url';</script>"; 

callback.php

<?php 
session_start(); 
include_once '../../winsinclude/tw_config.php'; 
require_once "../../winsinclude/twitteroauth.php"; 
require_once "../../winsinclude/OAuth.php"; 

if (
    isset($_REQUEST['oauth_token']) 
    && $_SESSION['oauth_token'] !== $_REQUEST['oauth_token'] 
) { 
    echo 'Session expired'; 
} 
else { 
    $connection = new TwitterOAuth(
    CONSUMER_KEY, 
    CONSUMER_SECRET, 
    $_SESSION['oauth_token'], 
    $_SESSION['oauth_token_secret'] 
); 
    $_SESSION['access_token'] = $connection->getAccessToken($_REQUEST['oauth_verifier']); 
    print "<script>self.location='index.php';</script>"; 
} 

回答

0

最近的Twitter停用一個數的HTTP URL的用於OAUTH和以https等同替換它們。如果您可以在包含中看到URL字符串http://twitter.com/oauth/request_token,那麼這意味着您需要關注https://dev.twitter.com/discussions/10803並將所有呼叫更改爲https ...

+0

如果您閱讀我發佈的源代碼,您會看到我沒有打電話給twitter API沒有特定的終點,我使用的是Abraham Williams的庫,它不使用特定的終點就不調用API庫。 – user1742322