>백엔드 개발 >PHP 튜토리얼 >PHP에서 사용자 로그인을 구현하는 간단한 방법

PHP에서 사용자 로그인을 구현하는 간단한 방법

墨辰丷
墨辰丷원래의
2018-05-24 10:36:111934검색

이 글은 주로 php에서의 간단한 사용자 로그인 예시에 대한 내용을 소개하고 있습니다. 필요한 친구들은 참고하시면 됩니다

php에서의 간단한 사용자 로그인 예시

서문:

마지막 부분은 최근에 완성하겠습니다. 사용자가 제출한 데이터를 관리하는 것은 관리자의 업무여야 하며, 로그인, 계정 권한 확인, 계정 만료 여부 등이 포함되어야 합니다.

필수 지식

세션은 정말 중요합니다. 그리고 세션이 페이지를 넘을 수 없다는 문제가 발생하여 PHP.ini의 session.use_trans_sid = 0 값을 1로 수정했습니다.

특정 구현

제 백엔드 디자인은 비교적 간단합니다. 비밀번호만 입력하면 됩니다. 이 비밀번호는 물론 서버에 저장되며 변경할 수 있습니다. 따라서 세션에 플래그와 시간이라는 두 가지 변수만 추가하면 됩니다.

먼저 플래그를 사용하여 관리자가 성공적으로 로그인했는지 확인하고, 시간을 사용하여 로그인 시간이 초과되었는지 확인합니다. 비밀번호를 제출한 후 비밀번호가 정확하면 플래그에 값 1이 할당되고 시간은 현재 시간이 할당됩니다. 새 페이지에 들어가거나 작업을 수행할 때마다 이 두 변수를 판단합니다. 먼저 플래그 값이 1인지 판단합니다. 고유하지 않으면 로그인되지 않았음을 직접 알리고 세션을 삭제합니다. 1이면 현재 시간 -$_SESSION('time')이 600(10분)보다 작은 것으로 판단합니다. 이 값이 600(10분)보다 크면 로그인 시간 초과 메시지가 표시되고 그보다 작으면 세션이 삭제됩니다. 작업이 허용되고 시간 변수 값이 현재 값으로 업데이트됩니다.

코드의 일부

check_pw.php

<?php
session_start();
$_SESSION[&#39;flag&#39;] = 0;
$myfile = fopen("passwd","r") or die("Unable to open file!");
$passwd = fgets($myfile);
if(empty($_POST[&#39;pass&#39;])){
  echo "不能为空,重新输入";
  $page = "login.html";
}else{
  $pass = $_POST[&#39;pass&#39;];
  $passwd = test_input($passwd);
  $pass = test_input($pass);
  if($pass == $passwd){
    echo "口令正确,允许访问";
    $page = "list_all.php";
    $_SESSION[&#39;flag&#39;] = 1;
    $_SESSION[&#39;time&#39;] = time(); //当前秒数
  }else{
    echo "口令错误,重新输入";
    $page = "login.html";
  }
}

function test_input($date){
  $date = trim($date);
  $date = stripcslashes($date);
  $date = htmlspecialchars($date);
  return $date;
}
?>
  <a href="<?php echo $page;?>" rel="external nofollow" >点此跳转</a>

list_all.php (part)

<?php
session_start();
if($_SESSION[&#39;flag&#39;] == 1){
  if(time() - $_SESSION[&#39;time&#39;] > 600){
    echo "登陆超时";
    echo &#39;<a href="login.html" rel="external nofollow" rel="external nofollow" >点此登陆</a>&#39;;
    session_destroy();
    exit();
  }else{
  $_SESSION[&#39;time&#39;] = time();
  }
}else{
  echo "未登陆,无权访问!";
  echo &#39;<a href="login.html" rel="external nofollow" rel="external nofollow" >点此登陆</a>&#39;;
  session_destroy();
  exit();
}
?>

위 내용은 이 글의 전체 내용입니다. 모두의 공부에 도움이 됩니다.


관련 권장 사항:

php+mysql은 가장 간단한 온라인 질문 은행 및 온라인 질문 작성 시스템을 개발합니다

PHP차별화된 기업 WeChat 브라우저 | 일반 WeChat 브라우저 | 기타 브라우저

PHP

특정 요소를 기반으로 한 2차원 배열 중복 제거

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

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