>백엔드 개발 >PHP 문제 >PHP에서 간단한 비밀번호 로그인을 구현하는 방법

PHP에서 간단한 비밀번호 로그인을 구현하는 방법

藏色散人
藏色散人원래의
2022-01-18 10:51:335402검색

PHP에서 간단한 비밀번호 로그인을 구현하는 방법: 1. login.html을 생성합니다. 3. 사용자 로그인 정보를 처리합니다. 4. 기본 홈페이지 index.php를 설정합니다.

PHP에서 간단한 비밀번호 로그인을 구현하는 방법

이 기사의 운영 환경: Windows 7 시스템, PHP 버전 7.1, DELL G3 컴퓨터

PHP에서 간단한 비밀번호 로그인을 구현하는 방법은 무엇입니까?

PHP는 가장 간단한 로그인 인터페이스를 구현합니다

이것은 PHP를 배우는 과정에서 처음으로 완료되는 매우 작은 프로젝트입니다. 마침내 프로젝트를 수행하고 특별히 기록을 만들었습니다

로그인 인터페이스:

html 코드 (login.html):

<form action="login.php" method="post">
		<fieldset>
			<legend>用户登录</legend>
			<ul>
				<li>
					<label>用户名:</label>
					<input type="text" name="username">
				</li>
				<li>
					<label>密   码:</label>
					<input type="password" name="password">
				</li>
				<li>
					<label> </label>
					<input type="checkbox" name="remember" value="yes">7天内自动登录
				</li>
				<li>
					<label> </label>
					<input type="submit" name="login" value="登录">
				</li>
			</ul>
		</fieldset>
	</form>

login.php: (로그인 처리 페이지)

<?php 
	header(&#39;Content-type:text/html; charset=utf-8&#39;);
	// 开启Session
	session_start();

	// 处理用户登录信息
	if (isset($_POST[&#39;login&#39;])) {
		# 接收用户的登录信息
		$username = trim($_POST[&#39;username&#39;]);
		$password = trim($_POST[&#39;password&#39;]);
		// 判断提交的登录信息
		if (($username == &#39;&#39;) || ($password == &#39;&#39;)) {
			// 若为空,视为未填写,提示错误,并3秒后返回登录界面
			header(&#39;refresh:3; url=login.html&#39;);
			echo "用户名或密码不能为空,系统将在3秒后跳转到登录界面,请重新填写登录信息!";
			exit;
		} elseif (($username != &#39;username&#39;) || ($password != &#39;password&#39;)) {
			# 用户名或密码错误,同空的处理方式
			header(&#39;refresh:3; url=login.html&#39;);
			echo "用户名或密码错误,系统将在3秒后跳转到登录界面,请重新填写登录信息!";
			exit;
		} elseif (($username = &#39;username&#39;) && ($password = &#39;password&#39;)) {
			# 用户名和密码都正确,将用户信息存到Session中
			$_SESSION[&#39;username&#39;] = $username;
			$_SESSION[&#39;islogin&#39;] = 1;
			// 若勾选7天内自动登录,则将其保存到Cookie并设置保留7天
			if ($_POST[&#39;remember&#39;] == "yes") {
				setcookie(&#39;username&#39;, $username, time()+7*24*60*60);
				setcookie(&#39;code&#39;, md5($username.md5($password)), time()+7*24*60*60);
			} else {
				// 没有勾选则删除Cookie
				setcookie(&#39;username&#39;, &#39;&#39;, time()-999);
				setcookie(&#39;code&#39;, &#39;&#39;, time()-999);
			}
			// 处理完附加项后跳转到登录成功的首页
			header(&#39;location:index.php&#39;);
		}
	}
 ?>

index.php (기본 홈페이지):

<?php 
	header(&#39;Content-type:text/html; charset=utf-8&#39;);
	// 开启Session
	session_start();

	// 首先判断Cookie是否有记住了用户信息
	if (isset($_COOKIE[&#39;username&#39;])) {
		# 若记住了用户信息,则直接传给Session
		$_SESSION[&#39;username&#39;] = $_COOKIE[&#39;username&#39;];
		$_SESSION[&#39;islogin&#39;] = 1;
	}
	if (isset($_SESSION[&#39;islogin&#39;])) {
		// 若已经登录
		echo "你好! ".$_SESSION[&#39;username&#39;].&#39; ,欢迎来到个人中心!<br>';
		echo "<a href=&#39;logout.php&#39;>注销</a>";
	} else {
		// 若没有登录
		echo "您还没有登录,请<a href=&#39;login.html&#39;>登录</a>";
	}
 ?>

logout.php 로그아웃 페이지

<?php 
	header(&#39;Content-type:text/html; charset=utf-8&#39;);
	// 注销后的操作
	session_start();
	// 清除Session
	$username = $_SESSION[&#39;username&#39;];  //用于后面的提示信息
	$_SESSION = array();
	session_destroy();

	// 清除Cookie
	setcookie(&#39;username&#39;, &#39;&#39;, time()-99);
	setcookie(&#39;code&#39;, &#39;&#39;, time()-99);

	// 提示信息
	echo "欢迎下次光临, ".$username.&#39;<br>';
	echo "<a href=&#39;login.html&#39;>重新登录</a>";

 ?>

로그인 성공 상태 :


7일 이내에 자동 로그인을 체크하시면 쿠키와 세션 기술을 통해 로그인 정보가 로컬 쿠키 파일에 저장되며, 7일 이내에 자동으로 로그인됩니다.

로그아웃 페이지:


로그인 오류의 여러 상황이 처리되었습니다.



제가 직접 PHP를 배우기 위해 동영상을 봤는데 첫 번째는 Xiaoxiaoxiao 프로젝트, 상사 여러분, '냉담한 주먹'을 치지 마세요

추천 학습: "PHP 비디오 튜토리얼"

위 내용은 PHP에서 간단한 비밀번호 로그인을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.