通过 php 成功连接到 Google Contacts API 后,我如何/什么存储在数据库中以便稍后重新连接?

发布于 2024-10-14 14:36:28 字数 3085 浏览 6 评论 0原文

所以这就是交易。

我已经通过 php 连接到 Google 联系人的 api,将所有内容存储在会话中,并检索了联系人列表。

我想要的是将所有必要的令牌存储在数据库中,并在稍后检索它们以在同一用户上重新使用它们。我不知道要存储什么信息...我尝试将会话中的每个小项目存储到数据库中,并在尝试重新连接到 api 时重新加载它,但总是会出现一个或另一个错误,因为我的令牌是不正确。

我想对于了解 OAuth 的人来说答案很简单 - 这实际上只是一个我存储什么的问题。

代码如下:

<?php
session_start();

include_once "../oauth-php/library/OAuthStore.php";
include_once "../oauth-php/library/OAuthRequester.php";

global $db;

$userid=$_SESSION['userid'];

define("GOOGLE_CONSUMER_KEY", "website.com"); // 
define("GOOGLE_CONSUMER_SECRET", "----------------------"); // 

define("GOOGLE_OAUTH_HOST", "https://www.google.com");
define("GOOGLE_REQUEST_TOKEN_URL", GOOGLE_OAUTH_HOST . "/accounts/OAuthGetRequestToken");
define("GOOGLE_AUTHORIZE_URL", GOOGLE_OAUTH_HOST . "/accounts/OAuthAuthorizeToken");
define("GOOGLE_ACCESS_TOKEN_URL", GOOGLE_OAUTH_HOST . "/accounts/OAuthGetAccessToken");

define('OAUTH_TMP_DIR', function_exists('sys_get_temp_dir') ? sys_get_temp_dir() : realpath($_ENV["TMP"]));

//  Init the OAuthStore
$options = array(
 'consumer_key' => GOOGLE_CONSUMER_KEY, 
 'consumer_secret' => GOOGLE_CONSUMER_SECRET,
 'server_uri' => GOOGLE_OAUTH_HOST,
 'request_token_uri' => GOOGLE_REQUEST_TOKEN_URL,
 'authorize_uri' => GOOGLE_AUTHORIZE_URL,
 'access_token_uri' => GOOGLE_ACCESS_TOKEN_URL
);

OAuthStore::instance("Session", $options);


try
{
 //  STEP 1:  If we do not have an OAuth token yet, go get one
 if (empty($_GET["oauth_token"]))
 {
  $getAuthTokenParams = array('scope' => 
   'https://www.google.com/m8/feeds/',
   'xoauth_displayname' => 'My web app',
   'oauth_callback' => 'http://website.com/google.php');

  // get a request token
  $tokenResultParams = OAuthRequester::requestRequestToken(GOOGLE_CONSUMER_KEY, 0, $getAuthTokenParams);
  //  redirect to the google authorization page, they will redirect back
  header("Location: " . GOOGLE_AUTHORIZE_URL . "?btmpl=mobile&oauth_token=" . $tokenResultParams['token']);
 }
 else {
  //  STEP 2:  Get an access token
  $oauthToken = $_GET["oauth_token"];
  $oauthVerifier = $_GET["oauth_verifier"];
  $tokenResultParams = $_GET;

  //$db->query("UPDATE gmkeys SET token='$oauthToken', secrettoken='$oauthVerifier'");
  try {
      OAuthRequester::requestAccessToken(GOOGLE_CONSUMER_KEY, $oauthToken, 0, 'POST', $_GET);
  }
  catch (OAuthException2 $e)
  {
   var_dump($e);
      // Something wrong with the oauth_token.
      // Could be:
      // 1. Was already ok
      // 2. We were not authorized
      return;
  }

  // make the request.
  $request = new OAuthRequester("https://www.google.com/m8/feeds/contacts/default/full?max-results=1000&group=http%3A%2F%2Fwww.google.com%2Fm8%2Ffeeds%2Fgroups%2Fusernamehere%40gmail.com%2Fbase%2F6", 'GET', $tokenResultParams);


  $result = $request->doRequest(0);
  if ($result['code'] == 200) 
  {
   $xml = new SimpleXMLElement($result['body']);
   ...
  }
  else 
  {
   echo 'Error';
  }
 }
}
catch(OAuthException2 $e) {
 echo "OAuthException:  " . $e->getMessage();
 var_dump($e);
}
?>

So here's the deal.

I've connected to Google contact's api via php, stored everything in sessions, and retrieved a list of contacts.

What I want is to store all the necessary tokens in a database, and retrieve them at a later time to re-use them on the same user. I can't figure out what information to store... I've attempted storing every little item from the session into a database and reloading it when I try to reconnect to the api, but always get one error or another because my tokens aren't correct.

I imagine the answer is simple to someone who understands OAuth well - it's really just a question of what do I store.

Code below:

<?php
session_start();

include_once "../oauth-php/library/OAuthStore.php";
include_once "../oauth-php/library/OAuthRequester.php";

global $db;

$userid=$_SESSION['userid'];

define("GOOGLE_CONSUMER_KEY", "website.com"); // 
define("GOOGLE_CONSUMER_SECRET", "----------------------"); // 

define("GOOGLE_OAUTH_HOST", "https://www.google.com");
define("GOOGLE_REQUEST_TOKEN_URL", GOOGLE_OAUTH_HOST . "/accounts/OAuthGetRequestToken");
define("GOOGLE_AUTHORIZE_URL", GOOGLE_OAUTH_HOST . "/accounts/OAuthAuthorizeToken");
define("GOOGLE_ACCESS_TOKEN_URL", GOOGLE_OAUTH_HOST . "/accounts/OAuthGetAccessToken");

define('OAUTH_TMP_DIR', function_exists('sys_get_temp_dir') ? sys_get_temp_dir() : realpath($_ENV["TMP"]));

//  Init the OAuthStore
$options = array(
 'consumer_key' => GOOGLE_CONSUMER_KEY, 
 'consumer_secret' => GOOGLE_CONSUMER_SECRET,
 'server_uri' => GOOGLE_OAUTH_HOST,
 'request_token_uri' => GOOGLE_REQUEST_TOKEN_URL,
 'authorize_uri' => GOOGLE_AUTHORIZE_URL,
 'access_token_uri' => GOOGLE_ACCESS_TOKEN_URL
);

OAuthStore::instance("Session", $options);


try
{
 //  STEP 1:  If we do not have an OAuth token yet, go get one
 if (empty($_GET["oauth_token"]))
 {
  $getAuthTokenParams = array('scope' => 
   'https://www.google.com/m8/feeds/',
   'xoauth_displayname' => 'My web app',
   'oauth_callback' => 'http://website.com/google.php');

  // get a request token
  $tokenResultParams = OAuthRequester::requestRequestToken(GOOGLE_CONSUMER_KEY, 0, $getAuthTokenParams);
  //  redirect to the google authorization page, they will redirect back
  header("Location: " . GOOGLE_AUTHORIZE_URL . "?btmpl=mobile&oauth_token=" . $tokenResultParams['token']);
 }
 else {
  //  STEP 2:  Get an access token
  $oauthToken = $_GET["oauth_token"];
  $oauthVerifier = $_GET["oauth_verifier"];
  $tokenResultParams = $_GET;

  //$db->query("UPDATE gmkeys SET token='$oauthToken', secrettoken='$oauthVerifier'");
  try {
      OAuthRequester::requestAccessToken(GOOGLE_CONSUMER_KEY, $oauthToken, 0, 'POST', $_GET);
  }
  catch (OAuthException2 $e)
  {
   var_dump($e);
      // Something wrong with the oauth_token.
      // Could be:
      // 1. Was already ok
      // 2. We were not authorized
      return;
  }

  // make the request.
  $request = new OAuthRequester("https://www.google.com/m8/feeds/contacts/default/full?max-results=1000&group=http%3A%2F%2Fwww.google.com%2Fm8%2Ffeeds%2Fgroups%2Fusernamehere%40gmail.com%2Fbase%2F6", 'GET', $tokenResultParams);


  $result = $request->doRequest(0);
  if ($result['code'] == 200) 
  {
   $xml = new SimpleXMLElement($result['body']);
   ...
  }
  else 
  {
   echo 'Error';
  }
 }
}
catch(OAuthException2 $e) {
 echo "OAuthException:  " . $e->getMessage();
 var_dump($e);
}
?>

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

小镇女孩 2024-10-21 14:36:28

access_token 和 request_token 字符串

The access_token and the request_token strings

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文