⊗ppPmAuRgtD 434 of 447 menu

Normalisering av databas

För närvarande lagrar vi våra användares statusar i samma tabell som användarna själva. Detta är dock felaktigt - vi får en onormaliserad tabell, eftersom orden 'user' och 'admin' upprepas många gånger.

Det är nödvändigt att utföra normalisering - låt oss flytta våra statusar till en separat tabell statuses:

id name
1 user
2 admin

Och i tabellen users skapar vi en kolumn status_id. Nu vid registrering kommer vi att skriva in id för statusen från tabellen statuses i kolumnen status_id:

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

De mest komplexa förändringarna kommer att ske vid auktorisering: för att få användarens status måste man utföra en LEFT JOIN:

<?php $login = $_POST['login']; // Hämtar användaren via inloggning och joinar status: $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 { } ?>

Omstrukturera er auktorisering och registrering i enlighet med beskrivningen i teorin.

Gör ändringar i adminpanelens funktion (visning av användarstatusar, ändring av statusar och så vidare).

Svenska
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Vi använder kakor för webbplatsens funktion, analys och personalisering. Behandling av data sker i enlighet med Integritetspolicyn.
acceptera alla anpassa avvisa