Diskuze: prihlas.php - Nevypisuje chybu pokud přihlášení selže.
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.
ak su udaje nespravne (nevrati ziadny vysledok z db) tak $sloupec['heslo'] neexistuje -> takze podmienku nevyhodnoti (myslim); preto je prazdna kedze server kvoli chybe v php nic nevracia
A v čem přesně by mohla být ta chyba? Přemýšlím tu nad tím už
nějakou dobu a né a né na to přijít...
V databázi v tabulce ncsdpk_uzivatele mám sloupce id, uzivatelske_jmeno,
email, heslo
A takto vypadá zdroják inputů, neboli prihlasit.php
<form action="prihlas.php" method="post">
<div class="input">
<?php echo $text['uzivatelske_jmeno']; ?>:</br>
<input type="text" name="uzivatelske_jmeno" placeholder="Uživatelské jméno" maxlength="20" />
</div>
<div class="input">
<?php echo $text['uzivatelske_heslo']; ?>:</br>
<input type="password" name="uzivatelske_heslo" placeholder="Heslo" maxlength="20" />
</div>
<div class="button">
<input type="submit" value="<?php echo $text['prihlasit']; ?>"/>
</div>
</form>
Možný bych zkusil vyhodit řádek
$sloupec = mysql_fetch_array($query) or die(mysql_error());
a hodil bych tam klasický
if($query == false)
{
echo mysql_error();
return;
}
$sloupec= mysql_fetch_array($query);
Další dvě věci - nehlídáš si Sqllnjection - kdyžtak si o tom něco najdi na netu. Každý by ti tam mohl hodit nějaký příkaz, který ti například smaže databázi.
A taky nepoužívej mysql, které je zastaralé, ale mysqli (http://php.net/…k.mysqli.php).
zdar,
spíš než na MySQLi se podívej na PDO, někde tu je na to návod (spolu s
parametrizovanými dotazy, které SQL injection řeší).
Pak máš zbytečnou podmínku s tím jménem, když tu podmínku máš už v
SQL dotazu.
Házet or die() k mysql_fetch_* nemá smysl, protože pak nemáš jak upozornit
uživatele, že zadal špatné jméno nebo heslo (vrací to FALSE v případě,
že se nenašly žádné záznamy, ne že je chyba v dotazu).
S tím heslem to máš stejně, podmínku máš už v SQL dotazu, takže ta v
PHP ztrácí význam.
Vsadím se, že ti to hází prázdnou stránku proto, že mysql_fetch_array() nenajde žádné záznamy (tzn. vrátí FALSE a provede se die(mysql_error())), to ale nic nevypíše, protože v SQL dotazu žádná chyba nebyla...
Jak by to šlo jednoduše s PDO? třeba takto
$pdo = new PDO("přihlašovací údaje do DB");
$query = $pdo->prepare("
SELECT data
FROM tabulka
WHERE jmeno = ? AND heslo = ?
LIMIT 1
");
$query->execute(array($jmeno, lepsi_hash_fce_nez_md5($heslo)));
$data = $query->fetch(PDO::FETCH_OBJ);
if ($data !== FALSE) {
// OK
} else {
echo "špatné jméno nebo heslo";
}
V podmínce WHERE záleží na velikosti písmen, takže pokud bys chtěl umožnit zadat jméno s různou velikostí znaků, použij LIKE
V podmínce WHERE záleží na velikosti písmen, takže pokud bys chtěl umožnit zadat jméno s různou velikostí znaků, použij LIKE
Jestli bude záležet na velikosti písmen závisí na použitém kódování
(respektive porovnávání) sloupce. Pokud je to zakončeno na
cs - case sensitive, tak záleží na velikosti písmen, pokud
je zakončeno na ci - case insensitive, tak na tom
nezáleží.
Př: utf8_czech_ci
Nepleteš si náhodou mysql a mysqli, že ne?
Fajn, přiznám se, že těmhle věcem nerozumim, takže jsem napsal něco z vlastní zkušenosti.
Neaktivní uživatel: náhodou nepletu a raději bych se podíval na PDO než
MySQLi. Viz např.
http://code.tutsplus.com/…e--net-24059
http://stackoverflow.com/…sqli-and-pdo
Já jen že nepoužívá mysqli, ale mysql
Myslím, že reagoval na větu:
A taky nepoužívej mysql, které je zastaralé, ale mysqli (http://php.net/…k.mysqli.php).
Zobrazeno 10 zpráv z 10.