⊗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ščinaShqipSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Користимо колачиће за рад сајта, аналитику и персонализацију. Обрада података се врши у складу са Политиком приватности.
прихвати све подеси одбиј