⊗ppPmAuRgtD 434 of 447 menu

Normalizimi i Bazës së të Dhënave

Tani ne i ruajmë statuset e përdoruesve tanë në të njëjtën tabelë ku janë vetë përdoruesit. Kjo, megjithatë, është e gabuar - ne kemi një tabelë të panormalizuar, pasi fjalët 'user' dhe 'admin' përsëriten shumë herë.

Është e nevojshme të kryhet normalizimi - le të nxjerrim statuset tona në një tabelë të veçantë statuses:

id name
1 user
2 admin

Dhe në tabelën users le të krijojmë një kolonë status_id. Tani gjatë regjistrimit ne në kolonën status_id do të shënojmë id e statusit nga tabela statuses:

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

Ndryshimet më të vështira do të ndodhin gjatë autorizimit: që të merret statusi i përdoruesit, do të duhet të kryhet LEFT JOIN:

<?php $login = $_POST['login']; // Marrim përdoruesin sipas login dhe bëjmë join statusin: $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 { } ?>

Riktheni autorizimin dhe regjistrimin tuaj në përputhje me atë që përshkruhet në teori.

Bëni ndryshime në funksionimin e adminit (shfaqja e statuseve të përdoruesve, ndryshimi i statuseve e kështu me radhë).

Shqip
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Ne përdorim cookie për funksionimin e sajtit, analizën dhe personalizimin. Përpunimi i të dhënave bëhet në përputhje me Politikën e Privatësisë.
prano të gjitha konfiguro refuzo