$client_id = 'XXXXXXXXXXXX'; // Application ID
$public_key = 'XXXXXXXXXXXXXXXXXXX'; // Публичный ключ приложения
$client_secret = 'XXXXXXXXXXXXXXXXXXX'; // Секретный ключ приложения
$redirect_uri = 'https://site.ru/social_login_callback/ok.php'; // Список разрешённых redirect_uri
if (isset($_GET['code'])) {
$params = array(
'code' => $_GET['code'],
'redirect_uri' => $redirect_uri,
'grant_type' => 'authorization_code',
'client_id' => $client_id,
'client_secret' => $client_secret
);
$url = 'https://api.ok.ru/oauth/token.do';
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $url); // url, куда будет отправлен запрос
curl_setopt($curl, CURLOPT_POST, 1);
curl_setopt($curl, CURLOPT_POSTFIELDS, urldecode(http_build_query($params))); // передаём параметры
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
$result = curl_exec($curl);
curl_close($curl);
$tokenInfo = json_decode($result, true);
if (isset($tokenInfo['access_token']) && isset($public_key)) {
$sign = md5("application_key={$public_key}format=jsonmethod=users.getCurrentUser" . md5("{$tokenInfo['access_token']}{$client_secret}"));
$params = array(
'method' => 'users.getCurrentUser',
'access_token' => $tokenInfo['access_token'],
'application_key' => $public_key,
'format' => 'json',
'sig' => $sign
);
}
$userInfo = json_decode(file_get_contents('https://api.ok.ru/fb.do' . '?' . urldecode(http_build_query($params))), true);
if (isset($userInfo['uid'])) {
$result = true;
}
$email = $userInfo['email'];
if ($result) {
echo "email: " . $userInfo['email'];
echo "Социальный ID пользователя: " . $userInfo['uid'];
echo "Имя пользователя: " . $userInfo['name'];
echo "Ссылка на профиль пользователя: " . 'httpы://ok.ru/profile/' . $userInfo['uid'];
echo "Пол пользователя: " . $userInfo['gender'];
echo "День Рождения: " . $userInfo['birthday'];
echo $userInfo['pic_2'];
}
}