⊗ppPmAuRgtD 434 of 447 menu

Нармалізацыя базы даных

Зараз мы захоўваем статусы нашых карыстальнікаў у той жа табліцы, дзе і саміх карыстальнікаў. Гэта, аднак, няправільна - у нас атрымліваецца не нармалізаваная табліца, бо словы 'user' і 'admin' паўтараюцца шмат разоў.

Неабходна выканаць нармалізацыю - вынясем нашы статусы ў асобную табліцу statuses:

id name
1 user
2 admin

А ў табліцы users зробім калонку status_id. Цяпер пры рэгістрацыі мы ў калонку status_id будзем запісваць id статуса з табліцы statuses:

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

Самыя складаныя змены адбудуцца пры аўтарызацыі: для таго, каб атрымаць статус карыстальніка, трэба будзе выканаць LEFT JOIN:

<?php $login = $_POST['login']; // Атрымліваем карыстальніка па лагіне і джойнім статус: $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']; // статус } else { } } else { } ?>

Перарабіце вашу аўтарызацыю і рэгістрацыю ў адпаведнасці з апісаным у тэорыі.

Унясіце змены ў працу адмінкі (вывад статусаў карыстальнікаў, змены статусаў і гэтак далей).

Беларуская
AfrikaansAzərbaycanБългарскиবাংলাČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Мы выкарыстоўваем cookie для працы сайта, аналітыкі і персаналізацыі. Апрацоўка дадзеных адбываецца згодна Палітыкай канфідэнцыяльнасці.
прыняць усе наладзіць адхіліць