인터넷이 널리 보급되면서 사용자 로그인 및 등록 시스템도 많은 웹사이트에서 필수적인 기능이 되었습니다. 이 기사에서는 PHP 언어를 통해 간단한 사용자 로그인 및 등록 시스템을 구현하겠습니다.
먼저 사용자 정보를 저장할 데이터베이스를 생성해야 합니다. 우리는 MySQL 데이터베이스를 사용하고 사용자 이름과 비밀번호를 저장하기 위해 "users"라는 테이블을 생성할 것입니다.
CREATE TABLE 사용자(
id INT(11) NOT NULL AUTO_INCREMENT, username VARCHAR(50) NOT NULL, password VARCHAR(255) NOT NULL, PRIMARY KEY (id)
);
다음으로 사용자가 사용자 이름과 비밀번호를 입력할 수 있도록 등록 페이지를 만들어야 합니다. 등록 페이지에서는 HTML 양식을 사용하여 사용자의 입력 정보를 수집하고 PHP 코드를 사용하여 이 정보를 데이터베이스에 삽입해야 합니다.
다음은 간단한 등록 페이지의 코드입니다:
<title>用户注册</title>
<h1>用户注册</h1> <form action="register.php" method="post"> <label>用户名:</label> <input type="text" name="username" required> <br><br> <label>密码:</label> <input type="password" name="password" required> <br><br> <input type="submit" value="注册"> </form>
body> ;
위 코드에서는 HTML 양식을 사용하여 사용자의 입력 정보를 수집하고 양식의 작업 속성을 "register.php"로 설정합니다. 양식에서 PHP 코드는 입력 정보를 처리합니다. 다음으로 이러한 입력을 처리하기 위해 Register.php 파일을 작성하겠습니다.
양식 데이터를 데이터베이스에 삽입하기 전에 입력 데이터가 유효한지 확인해야 합니다. 우리는 사용자 이름이 고유하고 비밀번호가 암호화되어 있는지 확인합니다. 다음은 Register.php 파일의 코드입니다:
// 사용자 입력 받기
$username = $_POST['username'];
$password = $_POST['password'];
// 데이터베이스 연결 테스트
$mysqli = new mysqli('localhost', 'root', '', 'test');
if ($mysqli->connect_errno) {
die('连接失败: '.$mysqli->connect_error);
}
// 사용자 이름은 고유합니다
$result = $mysqli->query("SELECT * FROM users WHERE username='$username'");
if ($result->num_rows > 0) {
die('用户名已存在');
}
// 암호화된 비밀번호
$password = 비밀번호_hash($password, PASSWORD_DEFAULT);
// 데이터베이스에 사용자 정보 삽입
$sql = "INSERT INTO 사용자 (사용자 이름, 비밀번호) VALUES ('$username', '$password' )";
if ( $mysqli->query($sql)) {
echo '注册成功';
} else {
echo '注册失败: '.$mysqli->error;
}
?>
위의 Register.php 파일에서 먼저 사용자 이름과 비밀번호를 입력합니다. 사용자에 의해. 다음으로 사용자 이름이 데이터베이스에 이미 존재하는지 확인합니다. 그런 다음, Password_hash 함수를 사용하여 비밀번호를 암호화합니다. 마지막으로 사용자 이름과 암호화된 비밀번호를 데이터베이스에 삽입합니다. 삽입이 성공하면 "등록 성공" 메시지가 출력됩니다. 그렇지 않으면 "등록 실패" 메시지가 출력됩니다.
다음으로, 사용자가 등록된 사용자 이름과 비밀번호를 입력할 수 있는 로그인 페이지를 생성하겠습니다. 로그인 페이지에서는 HTML 양식을 사용하여 사용자의 입력 정보를 수집하고 PHP 코드를 사용하여 사용자의 신원 정보를 인증합니다.
다음은 간단한 로그인 페이지의 코드입니다:
<title>用户登录</title>
<h1>用户登录</h1> <form action="login.php" method="post"> <label>用户名:</label> <input type="text" name="username" required> <br><br> <label>密码:</label> <input type="password" name="password" required> <br><br> <input type="submit" value="登录"> </form>
위 코드에서는 HTML 양식을 사용하여 사용자의 입력 정보를 수집하고 양식의 작업 속성을 "login.php"로 설정합니다. 이는 사용자가 양식을 제출할 때 , PHP 코드는 입력 정보를 처리합니다. 다음으로 사용자의 신원정보를 확인하기 위해 login.php 파일을 작성하겠습니다.
사용자의 로그인 요청을 처리하기 전에 입력된 데이터가 유효한지 확인해야 합니다. 사용자 이름이 존재하는지, 입력한 비밀번호가 데이터베이스의 비밀번호와 일치하는지 확인합니다. 다음은 login.php 파일의 코드입니다:
// 사용자 입력 받기
$username = $_POST['username'];
$password = $_POST['password'];
// 데이터베이스 연결 테스트
$mysqli = new mysqli('localhost', 'root', '', 'test');
if ($mysqli->connect_errno) {
die('连接失败: '.$mysqli->connect_error);
}
// 사용자 이름이 존재합니다
$result = $mysqli->query("SELECT * FROM users WHERE 사용자 이름='$username'");
if ($result->num_rows == 0) {
die('用户名不存在,请检查输入');
}
// 비밀번호가 유효한지 확인하세요. Correct
$user = $result->fetch_assoc();
if (!password_verify($password, $user['password'])) {
die('密码错误,请检查输入');
}
echo '환영합니다'. $username;
?> ;
위의 login.php 파일에서 먼저 사용자가 입력한 사용자 이름과 비밀번호를 가져옵니다. 다음으로 사용자 이름이 데이터베이스에 존재하는지 확인합니다. 그런 다음 데이터베이스에서 해당 사용자의 비밀번호를 가져오고 비밀번호 확인 기능을 사용하여 입력된 비밀번호가 데이터베이스의 비밀번호와 일치하는지 확인합니다. 비밀번호가 일치하면 환영 메시지가 출력됩니다. 그렇지 않으면 오류 메시지를 인쇄하고 프로그램을 종료합니다.
이 시점에서 간편 사용자 로그인 및 등록 시스템 구현이 완료되었습니다. 이 시스템을 통해 사용자는 웹사이트에 계정을 등록하고 로그인하여 특정 페이지에 액세스할 수 있습니다. 물론 이는 가장 기본적인 구현 방법일 뿐이며, 실제 애플리케이션에서는 시스템의 가용성과 보안을 보장하기 위해 더 복잡한 기능이 필요합니다.
위 내용은 PHP를 사용하여 사용자 로그인 및 등록 시스템 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!