⊗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
우리는 웹사이트 운영, 분석 및 개인화를 위해 쿠키를 사용합니다. 데이터 처리는 개인정보 처리방침에 따라 이루어집니다.
모두 수락 설정 거부