⊗ppPmAuRgtD 434 of 447 menu

Maglumatlar bazasynyň normalizasiýasy

Häzirki wagtda ulanyjylarymyzyň statuslaryny, ulanyjylaryň özleri ýerleşýän şol bir tablisada saklaýarys. Emma bu ýalňyş - normalizirlenmedik tablisa döreýär, sebäbi 'user' we 'admin' sözleri köp gezek gaýtalanýar.

Normalizasiýany ýerine ýetirmek zerur - statuslarymyzy aýratyn statuses tablisasyna geçirýäris:

id name
1 user
2 admin

users tablisasynda bolsa status_id sütüni döredýäris. Indi registrasiýa wagty status_id sütüne statuses tablisasyndaky statusyň id-sini ýazarys:

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

Iň kyn üýtgeşmeler awtorizasiýada bolar: ulanyjynyň statusyny almak üçin LEFT JOIN ýerine ýetirmeli bolýar:

<?php $login = $_POST['login']; // Ulanyjyny logine görä alyň we statusy goşuň: $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 { } ?>

Siziň awtorizasiýa we registrasiýa işiňizi teoriýada beýan edilen ýaly üýtgediň.

Admin paneliniň işine üýtgeşmeler giriziň (ulanyjylaryň statuslaryny görkezmek, statuslary üýtgetmek we ş.m.).

Türkmen
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkçeЎзбекOʻzbekTiếng Việt
Biz sahypanyň işlemegi, analitika we şahsyýetleşdirmek üçin cookie ulanýarys. Maglumatlaryň işlenişi Gizlinlik syýasaty boýunça amala aşyrylýar.
hemmesini kabul et sazlamak ret et