⊗ppPmAuRgtD 434 of 447 menu

Tietokannan normalisointi

Tällä hetkellä tallennamme käyttäjien tilamme samaan tauluun, jossa käyttäjät itse ovat. Tämä on kuitenkin väärin - saamme ei-normalisoidun taulun, koska sanat 'user' ja 'admin' toistuvat monta kertaa.

On tarpeen suorittaa normalisointi - siirretään tilamme erilliseen statuses-tauluun:

id name
1 user
2 admin

Ja users-taulussa teemme sarakkeen status_id. Nyt rekisteröityessä kirjoitamme sarakkeeseen status_id id-statuksen statuses-taulusta:

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

Vaikeimmat muutokset tapahtuvat autorisoinnissa: saadaksesi käyttäjän tilan, on suoritettava LEFT JOIN:

<?php $login = $_POST['login']; // Saadaan käyttäjä loginilla ja yhdistetään 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 { } ?>

Muuta autorisointisi ja rekisteröintisi teoriassa kuvatun mukaisesti.

Tee muutokset admin-työkalujen toimintaan (käyttäjien tilojen näyttäminen, tilojen muutokset jne.).

Suomi
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Käytämme evästeitä verkkosivuston toiminnalle, analytiikalle ja personoinnille. Tietojen käsittely tapahtuu Tietosuojakäytännön mukaisesti.
hyväksy kaikki mukauta hylkää