Autor | Zpráva | ||
---|---|---|---|
MartinJ Profil * |
#1 · Zasláno: 18. 6. 2016, 11:00:05
Dobrý den. Potřeboval bych pomoct. Stahl jsem si template webové stránky, běží to na Smarty enginu. Nezapisuji se mi informace získané pres Steam API do SQL databáze. Při přihlášení se v databázi uživatel vytvoří ale nezapíší se k němu žádné informace. Tudíž při odhlášení a dalším přihlášení se vytvoří nový uživatel. Tady je kus kódu z indexu:
case 'login': include 'openid.php'; try { $openid = new LightOpenID('http://'.$_SERVER['SERVER_NAME'].'/'); if (!$openid->mode) { $openid->identity = 'http://steamcommunity.com/openid/?l=english'; header('Location: ' . str_replace("csgobananas", "csgorebel", $openid->authUrl())); } elseif ($openid->mode == 'cancel') { echo ''; } else { if ($openid->validate()) { $id = $openid->identity; $ptn = "/^http:\/\/steamcommunity\.com\/openid\/id\/(7[0-9]{15,25}+)$/"; preg_match($ptn, $id, $matches); $url = "http://api.steampowered.com/ISteamUser/GetPlayerSummaries/v0002/?key=48AF41E2A9E460F36469498B6D211143&steamids=$matches[1]"; $json_object = file_get_contents($url); $json_decoded = json_decode($json_object); foreach ($json_decoded->response->players as $player) { $steamid = $player->steamid; $name = $player->personaname; $avatar = $player->avatar; } $hash = md5($steamid . time() . rand(1, 50)); $sql = $db->query("SELECT * FROM `users` WHERE `steamid` = '" . $steamid . "'"); $row = $sql->fetchAll(PDO::FETCH_ASSOC); if (count($row) == 0) { $db->exec("INSERT INTO `users` (`hash`, `steamid`, `name`, `avatar`) VALUES ('" . $hash . "', '" . $steamid . "', " . $db->quote($name) . ", '" . $avatar . "')"); } else { $db->exec("UPDATE `users` SET `hash` = '" . $hash . "', `name` = " . $db->quote($name) . ", `avatar` = '" . $avatar . "' WHERE `steamid` = '" . $steamid . "'"); } setcookie('hash', $hash, time() + 3600 * 24 * 7, '/'); header('Location: http://www.playground.cekuj.net/sets.php?id=' . $hash); } } } catch (ErrorException $e) { exit($e->getMessage()); } break; Vážně nevim, kde by mela být chyba. Přístup k databázi to má, nejspíš mi steam nechce vydat informace o uživateli, ale API klíč, který je součástí toho odkazu jsem změnil za můj. Také bych rad věděl, k čemu je tam to str_replace (to jsem neprepisoval a zůstala tam hodnota "csgobananas" z původního projektu, od kterého mam ten template. |
||
Časová prodleva: 9 let
|
0