⊗ppPmAuRgtD 434 of 447 menu

Normalizacja bazy danych

Obecnie przechowujemy statusy naszych użytkowników w tej samej tabeli, co samych użytkowników. Jest to jednak nieprawidłowe - otrzymujemy zdenormalizowaną tabelę, ponieważ słowa 'user' i 'admin' powtarzają się wiele razy.

Należy przeprowadzić normalizację - wydzielmy nasze statusy do osobnej tabeli statuses:

id name
1 user
2 admin

A w tabeli users utwórzmy kolumnę status_id. Teraz podczas rejestracji będziemy zapisywać w kolumnie status_id id statusu z tabeli statuses:

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

Najbardziej złożone zmiany zajdą przy autoryzacji: aby uzyskać status użytkownika, trzeba będzie wykonać LEFT JOIN:

<?php $login = $_POST['login']; // Pobieramy użytkownika po loginie i łączymy ze statusem: $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']; // status } else { } } else { } ?>

Przerób swoją autoryzację i rejestrację zgodnie z opisem w teorii.

Wprowadź zmiany w działaniu panelu administratora (wyświetlanie statusów użytkowników, zmiana statusów i tak dalej).

Polski
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Wykorzystujemy pliki cookie do działania strony, analizy i personalizacji. Przetwarzanie danych odbywa się zgodnie z Polityką prywatności.
zaakceptuj wszystkie dostosuj odrzuć