Diskuze: Včera registrace, dnes přihlášení :(
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 10 zpráv z 10.
//= 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,
nemáš v databázi uložené ještě staré hashe?
Jen takový detail. Druhý DB dotaz, kde máš WHERE aktivovan = 1, je zbytečný. Na data pro daného uživatele ses dotazoval jíž předtím, tak ti stačí jen udělat fetch a zkontrolovat, jestli ta hodnota se rovná 1.
<?php
$login = mysql_real_escape_string($_POST["nick"]);
$heslo1 = mysql_real_escape_string($_POST["heslo"]);
$heslo=hash_hmac("SHA512", "$heslo1", "$login");
$dotaz = mysql_query("select * from users where username = '$login' and pw = '$heslo'");
$overeni = mysql_num_rows($dotaz);
$row = mysql_fetch_array($dotaz);
if ($overeni == 1) {
if ($row["aktivovan"] == 1) {
// ...
}
}
Jinak je obecně lepší nepoužívat mysql_fetch_array(), ale
mysql_fetch_assoc(), které ti vytvoří pouze asociativní pole.
Pokud hledáš jen hodnotu jednoho sloupce, můžeš použít:
$dotaz = mysql_query("SELECT sloupec FROM tabulka WHERE podmínka");
$hodnotaSloupce = mysql_result($dotaz, 0);
Btw, když odpovídáš, je lepší stisknout na "Odpovědět", zobrazí se mi to pak v událostech a nemusím se dívat, jestli někdo nepřidal příspěvek.
Jestli to teda ještě dobře chápu, tak použiji mysql_result takto:
$dotaz=mysql_query("SELECT * FROM users WHERE email='$email' AND username='$nick'");
$overeni=mysql_result($dotaz, 0)
Když mi to hodí false, spíše 0, tak ten záznam v DB není, pokud to hodí 1, tka tam záznam je. Chápu to dobře?
Podle dokumentace to vrátí při úspěchu výsledek (hodnotu sloupce), jinak FALSE. Nejsem si jistý, ale podle mě to FALSE vyhodí v případě, že se nesplní podmínka a nenajde se žádná hodnota (alespoň v PDO to tak funguje).
Zobrazeno 10 zpráv z 10.