Twitter OAuth - Хранение токенов в MySql - PullRequest
6 голосов
/ 20 августа 2010

Я использую класс Twitter OAuth для подключения к Твиттеру, найденному здесь:

В настоящее время скрипт просто использует поставленные токены, но не сохраняет их в базе данных, я хотел бы, чтобы скрипт сделал это.

Вот что у меня есть в моем скрипте обратного вызова:

<?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/twitteroauth.php');
require_once('config.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: ./index.php');
} else {
  /* Save HTTP status for error dialog on connnect page.*/
  header('Location: ./clearsessions.php');
}

Как я могу сохранить токены в MySql, в какой части скрипта я получаю токены?

1 Ответ

6 голосов
/ 24 августа 2010

Необходимые данные хранятся в переменной $_SESSION['access_token'] = $access_token;.

Попробуйте print_r($access_token);

Внутри этой переменной вы найдете:

screen_name
user_id
oauth_token
oauth_token_secret

Что можетиспользоваться для вашего приложения и храниться в вашей базе данных.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...