⊗ppPmAuRgtD 434 of 447 menu

Normalizarea bazei de date

În prezent, stările utilizatorilor noștri sunt stocate în aceeași tabelă cu utilizatorii înșiși. Aceasta, însă, este incorectă - obținem o tabelă nenormalizată, deoarece cuvintele 'user' și 'admin' se repetă de multe ori.

Este necesar să efectuăm normalizarea - vom muta stările noastre într-o tabelă separată statuses:

id name
1 user
2 admin

Iar în tabela users vom crea coloana status_id. Acum, la înregistrare în coloana status_id vom scrie id-ul stării din tabela statuses:

<?php $query = "INSERT INTO users SET login='$login', password='$password', status_id='1'"; ?>

Cele mai semnificative modificări vor avea loc la autentificare: pentru a obține starea utilizatorului, va trebui să executăm un LEFT JOIN:

<?php $login = $_POST['login']; // Obținem utilizatorul după login și join-im starea: $query = "SELECT users.*, statuses.name as status FROM users LEFT JOIN statuses ON users.status_id=statuses.id WHERE login='$login'"; $res = mysqli_query($link, $query); $user = mysqli_fetch_assoc($res); if (!empty($user)) { $hash = $user['password']; if (password_verify($_POST['password'], $hash)) { $_SESSION['auth'] = true; $_SESSION['status'] = $user['status']; // stare } else { } } else { } ?>

Refaceți autentificarea și înregistrarea în conformitate cu cele descrise în teorie.

Aduceți modificări în funcționarea panoului de administrare (afișarea stărilor utilizatorilor, modificarea stărilor și așa mai departe).

Română
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Folosim cookie pentru funcționarea site-ului, analiză și personalizare. Prelucrarea datelor are loc în conformitate cu Politica de confidențialitate.
acceptă toate configurează respinge