一个用户登录到我的网站,我拥有检索他们帐户信息所需的所有详细信息。我知道如何检索用户的个人资料图片url,但我不确定这是否是一个"静态"链接。如果它不是一个静态链接,我每次都必须获取URL,这就像一个坏主意。我真的会用我所有的请求来抨击谷歌。(我不担心谷歌服务器,我更担心我的api配额。)
那么,有没有一种方法可以获得用户配置文件图像的静态链接呢。如果没有,最好的选择是什么?
https://developers.google.com/+/政策状态,在B1c:部分
不要使用过时的数据。您可以缓存或存储通过Google+API获得的数据,但在应用程序的上下文中,尽可能使用最近从API获取的新数据。如果新数据显示内容不见了(例如,因为用户删除了它),请删除它,不要使用过时的副本。为了清楚起见,如果符合这些要求,则可以缓存比缓存头指定的时间更长的数据。
指南很模糊,很清楚,但它确实说你不应该每次都重新获取个人资料信息/照片。。。但您应该定期重新获取并存储它,至少在会话期间是这样。
既然你说的是照片,考虑一下人们可能会经常更改他们的照片。我想说,在用户会话期间缓存图像是有意义的,但在他们登录新会话时刷新它可能是合理的。
我用它来获取用户信息(和图像信息,并将其保存到数据库中以备将来使用)
$google_client_id = "MY GOOGLE CLIENT ID";
$google_client_secret = "MY GOOGLE CLIENT SECRET";
$redirect_URL = "http://url.to.redirect";
$gClient = new Google_Client ();
$gClient->setApprovalPrompt ("auto");
$gClient->setApplicationName ("My Application Name");
$gClient->setClientId ($google_client_id);
$gClient->setClientSecret ($google_client_secret);
$gClient->setRedirectUri ($redirect_URL);
$google_oauthV2 = new Google_Oauth2Service ($gClient);
//If user wish to log out, we just unset Session variable
if (isset ($_REQUEST["reset"]))
{
unset ($_SESSION["google"]["token"]);
$gClient->revokeToken ();
header ("Location: ".filter_var ($redirect_URL, FILTER_SANITIZE_URL));
}
if (isset ($_GET["code"]))
{
$gClient->authenticate ($_GET["code"]);
$_SESSION["google"]["token"] = $gClient->getAccessToken ();
header ("Location: ".filter_var ($redirect_URL, FILTER_SANITIZE_URL));
return;
}
if (isset ($_SESSION["google"]["token"]))
{
$gClient->setAccessToken ($_SESSION["google"]["token"]);
}
if ($gClient->getAccessToken ())
{
//Get user details if user is logged in
$google_data = $google_oauthV2->userinfo->get ();
$google_user = array (
"id" => $google_data["id"],
"email" => filter_var ($google_data["email"], FILTER_SANITIZE_EMAIL),
"profil_url" => filter_var ($google_data["link"], FILTER_VALIDATE_URL),
"picture" => filter_var ($google_data["picture"], FILTER_VALIDATE_URL)."?sz=200"
);
$_SESSION["google"]["token"] = $gClient->getAccessToken ();
// we have users data now so we do with it what we want... save to db?
}
else
{
//get google login url and redirect user to it
$login_url = $gClient->createAuthUrl ();
header ("Location: $login_url");
exit;
}