【发布时间】:2017-12-31 02:42:05
【问题描述】:
我有下一个代码,直接来自谷歌参考 (https://developers.google.com/identity/sign-in/web/backend-auth)
public function verifyFromAndroid($idToken=null) {
if(empty($idToken)) {
$idToken = self::SAMPLE_ID_TOKEN;
}
$client = new Google_Client(['client_id' => self::CLIENT_ID]);
$payload = $client->verifyIdToken($idToken);
if ($payload) {
print_r($payload);
$userid = $payload['sub'];
// If request specified a G Suite domain:
//$domain = $payload['hd'];
} else {
var_dump($payload);
$this->lastError = "Invalid ID token";
return false;
}
}
但此方法总是返回 false,即使使用使用 oauthplayground online tool 创建和工作的有效 id 令牌也是如此。
下一个代码可以正常工作,直接使用 GoogleAccessToken_Verify 类。谁能告诉我为什么官方的 Google 代码不起作用,是我自己的代码使用官方的 Google-clien-php sdk 吗?
try {
$verify = new Google_AccessToken_Verify();
$result = $verify->verifyIdToken($this->idToken);
if($result) {
print_r($result);
$friendlyData = $this->translateData($result, true);
if(!$friendlyData) {
return false;
}
return $friendlyData;
}
else {
$this->lastError = "Invalid token verification, no error code";
return false;
}
}
catch(UnexpectedValueException $ex) {
$this->lastError = "UnVaEx (Code {$ex->getCode()}): {$ex->getMessage()}";
return false;
}
【问题讨论】:
-
你是怎么解决这个问题的?
-
没有解决办法
标签: php google-signin