⊗ppPmAuRgtD 434 of 447 menu

Adatbázis normalizálás

Jelenleg a felhasználóink státuszait ugyanabban a táblában tároljuk, ahol magukat a felhasználókat. Ez azonban helytelen - nem normalizált táblát kapunk, hiszen a 'user' és 'admin' szavak sokszor ismétlődnek.

Végezzük el a normalizálást - helyezzük át státuszainkat egy külön statuses táblába:

id name
1 user
2 admin

A users táblában pedig készítsünk egy status_id oszlopot. Mostantól a regisztrációnál a status_id oszlopba a statuses táblából származó státusz id-ját írjuk:

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

A legbonyolultabb változtatások a hitelesítésnél történnek: ahhoz, hogy megkapjuk a felhasználó státuszát, LEFT JOIN-t kell végrehajtanunk:

<?php $login = $_POST['login']; // Lekérjük a felhasználót a felhasználónév alapján és összekapcsoljuk a státusszal: $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']; // státusz } else { } } else { } ?>

Alakítsa át a hitelesítés és regisztráció működését az elméletben leírtaknak megfelelően.

Végezze el a módosításokat az admin felület működésében (a felhasználók státuszainak megjelenítése, státuszok módosítása és így tovább).

Magyar
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
A weboldal működéséhez, elemzéshez és személyre szabáshoz sütiket használunk. Az adatfeldolgozás a Adatvédelmi irányelvek szerint történik.
összes elfogadása beállítás elutasítás