⊗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']; // Го добиваме корисникот по логин и го join-уваме статусот: $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šuMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Ние користиме колачиња за работата на веб-страната, анализа и персонализација. Обработката на податоци се врши во согласност со Политиката за приватност.
прифати ги сите прилагоди одбиј