Diskuze: Nechce mě to i přes správně zadané heslo přesměrovat.| LOGIN SYSTEM
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Zobrazeno 6 zpráv z 6.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Ahoj, první věc, co mě tak napadá, jestli jak jsi "natvrdo" zadával
uživatelské údaje do databáze, zda jsi jim vyplnil hesla ve správné
hashované podobě?
Hesla nejspíš uložil v plaintextu a teď je porovnává s hashem. To bude na 95 % ten problém.
Rozhodně jak píšou kluci. Když máš u přihlášení hash a záznamy ukládáš přímo v phpMyAdmin, tak to nikdy nemůže fungovat. Buď vymaž čtení otisku hesla při přihlášení, což nedoporučuji nebo si napiš registrační stránku, přes kterou vložíš uživatele do DB s otiskem hesla a pak ji klidně vymažeš z produkce. Pak ti vše bude fungovat. Koukám, že tam nemáš použity výjimky, takže ti to nevyhodí žádnou hlášku o chybě při špatném čtení otisku.
Trochu jsem to přepsal. Takhle to bude ideální nejspíše.
if($_POST)
{
if(Db::querySingle('SELECT user_id, user_password FROM users WHERE user_id=? AND user_password=?', $_POST['username'], hash('sha512', $_POST['password'])))
{
$_SESSION['uzivatel_id'] = $_POST['username'];
header('Location: administrace.php');
}
else
{
echo 'Chybová hláška dle libosti';
}
}
Nahraď toto
if ($_POST) {
$uzivatel = Db::queryOne('
SELECT user_id, user_password
FROM users
WHERE user_uid=?', $_POST['username']);
if (!empty($_POST['username']) || !empty($_POST['password'])) {
if (!password_verify($_POST['password'], $uzivatel['user_password'])) {
$zprava = "Nesprávné uživatelské jméno nebo heslo";
}
else {
$_SESSION['uzivatel_id'] = $uzivatel['user_id'];
$_SESSION['uzivatel_jmeno'] = $uzivatel['user_uid'];
header ('Location: administrace.php');
exit();
}
}
else {
$zprava ="Vyplňte prosím pole";
}
}
tím co jsem ti napsal. Zkus to. Rozhodně ještě předtím doporučuji do DB napsat otisk hesla. Kdyžtak to udělej takhle.
echo hash('sha512', 'nejakéheslosizdenapis');
a výsledek si ulož do DB. Nezapomeň ten řádek pak smazat
Ahoj,
Nevšiml jsem si, že ta funkce je pouze na hashované hesla, funkci jsem dal pryč a upravil a jede to. Díky moc.
Nyní mám však další problém. Nahrál jsem své soubory na cvičný free hosting a když se chci dostat do sekce s loginem napíše mi to error "stránka nemůže tento požadavek zpracovat HTTP error 500" co jsem tak hledal, tak je chyba s nějakým nastavení HTTP nebo co, setkal ses někdy s tím?
Zobrazeno 6 zpráv z 6.