⊗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 файлдарын қолданамыз. Деректерді өңдеу Құпиялылық саясаты бойынша жүреді.
барлығын қабылдау баптау қабылдамау