⊗ppPmAuRgtD 434 of 447 menu

База маалыматын нормалдаштыруу

Азыр биз колдонуучулардын статустарын колдонуучулардын өзү сакталган таблицада сактап жатабыз. Бирок, бул туура эмес - биздин таблицабыз нормалдаштырылган эмес, анткени 'user' жана 'admin' сөздөрү бир нече жолу кайталанып турат.

Нормалдаштырууну иштеп чыгуу керек - статустарыбызды statuses деген өзүнчө таблицага которобуз:

id name
1 user
2 admin

users таблицасында status_id колонкасын түзөбүз. Эми каттоодо status_id колонкасына биз statuses таблицасындагы статустун idин жазабыз:

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

Аутентификацияда эң татаал өзгөрүүлөр болот: колдонуучунун статусун алуу үчүн, LEFT JOIN аткаруу керек болот:

<?php $login = $_POST['login']; // Логин боюнча колдонуучуну алабыз жана статуска кошулабыз: $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']; // статус } else { } } else { } ?>

Теорияда сүрөттөлгөндөй, сиздин аутентификация жана каттоону кайра иштеп чыгыңыз.

Админ панелин иштөөсүнө өзгөртүүлөрдү киргизиңиз (колдонуучулардын статустарын көрсөтүү, статустарды өзгөртүү жана башкалар).

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