⊗ppPmAuRgtD 434 of 447 menu

Normalisering av databaser

For øyeblikket lagrer vi statusene til våre brukere i samme tabell som brukerne selv. Dette er imidlertid feil - vi får en ikke-normalisert tabell, fordi ordene 'user' og 'admin' gjentas mange ganger.

Det er nødvendig å utføre normalisering - la oss flytte statusene våre til en egen tabell statuses:

id name
1 user
2 admin

Og i tabellen users lager vi en kolonne status_id. Nå ved registrering vil vi i kolonnen status_id skrive id til statusen fra tabellen statuses:

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

De mest komplekse endringene vil skje ved autorisasjon: for å få brukerens status, må du utføre en LEFT JOIN:

<?php $login = $_POST['login']; // Henter brukeren ved login og joiner 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 { } ?>

Ombygg autorisasjonen og registreringen din i henhold til beskrevet i teorien.

Gjør endringer i arbeidet til adminpanelet (visning av brukerstatuser, endring av statuser og så videre).

Norsk
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Vi bruker informasjonskapsler for nettstedets funksjonalitet, analyse og personalisering. Behandling av data foregår i henhold til Personvernerklæringen.
godta alle tilpass avvis