⊗ppPmAuRgtD 434 of 447 menu

Penormalan Pangkalan Data

Sekarang kami menyimpan status pengguna kami dalam jadual yang sama dengan pengguna itu sendiri. Ini, bagaimanapun, tidak betul - kami mendapat jadual yang tidak dinormalisasi, kerana perkataan 'user' dan 'admin' diulang banyak kali.

Perlu melakukan normalisasi - kami akan mengeluarkan status kami ke jadual berasingan statuses:

id name
1 user
2 admin

Dan dalam jadual users, buat lajur status_id. Sekarang semasa pendaftaran kami akan menulis ke dalam lajur status_id id status dari jadual statuses:

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

Perubahan paling rumit akan berlaku semasa pengesahan: untuk mendapatkan status pengguna, perlu melakukan LEFT JOIN:

<?php $login = $_POST['login']; // Dapatkan pengguna dengan login dan join 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 { } ?>

Ubah suai pengesahan dan pendaftaran anda menurut yang diterangkan dalam teori.

Lakukan perubahan dalam kerja admin (paparan status pengguna, perubahan status dan sebagainya).

Melayu
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Kami menggunakan kuki untuk operasi laman web, analisis dan personalisasi. Pemprosesan data dijalankan mengikut Polisi Kerahsiaan.
terima semua tataletak tolak