我目前正在尝试使用 Google Identity Toolkit 实现忘记密码功能。PHP 后端正在尝试获取 oob 代码,因为客户端 (iOS) 没有足够的权限。
每当我运行脚本时,我都会收到错误INVALID_CREDENTIALS,更具体地说:
oob Code: string(249) "{ "error": { "errors": [ { "domain": "global", "reason": "authError", "message": "Invalid Credentials", "locationType": "header", "location": "Authorization" } ], "code": 401, "message": "Invalid Credentials" } } "
我不确定从哪里获取authToken或者这是否正确发送了发布请求。
$authToken = "xxxxxxxxxxxxxxxxx";
$email = $_POST['email'];
$uIp = $_POST['ip'];
//Post Data in Array
$postData = array(
'kind' => 'identitytoolkit#relyingparty',
'requestType' => 'PASSWORD_RESET',
'email' => '$email',
'challenge' => 'verified',
'captchaResp' => 'verified',
'userIp' => '$uIp',
'newEmail' => 'null',
'idToken' => 'null'
);
//Setup cURL
$ch = curl_init('https://www.googleapis.com/identitytoolkit/v3/relyingparty/getOobConfirmationCode?key=xxxxxxxxxxxxxxxxxxxx');
curl_setopt_array($ch, array(
CURLOPT_POST => TRUE,
CURLOPT_RETURNTRANSFER => TRUE,
CURLOPT_HTTPHEADER => array(
'Authorization: '.$authToken,
'Content-Type: application/json'
),
CURLOPT_POSTFIELDS => json_encode($postData)
));
//Send Request
$response = curl_exec($ch);