首頁 >後端開發 >php教程 >php實現使用者登陸簡單的方法

php實現使用者登陸簡單的方法

墨辰丷
墨辰丷原創
2018-05-24 10:36:111922瀏覽

這篇文章主要介紹了php實現使用者登陸簡單實例的相關資料,需要的朋友可以參考下

#php實作使用者登陸簡單實例

前言:

最近要完成的最後一個部分,就是對使用者提交的資料進行管理,至於管理,那肯定就是管理員的事了,那一定涉及登陸,驗證帳號權限,帳號是否過期等等問題。

所需知識

session,確實是很重要的東西。且我遇到session不能跨頁,修改PHP.ini的session.use_trans_sid = 0值為1。

具體實現

我的後台設計的比較簡單,只需輸入一個密碼即可,這個密碼當然是保存在伺服器可以更改的啦。所以只需要給session加兩個變量,flag、time。

首先,用flag確定管理員是否成功登陸,用time確定登陸是否逾時。提交密碼後,如果正確會給flag賦值為1,time賦值為目前時間。每次進入新的頁面或進行操作時會對這兩個變數進行判斷,首先判斷flag值是否為1,不唯一直接提示未登陸,銷毀session,如果為1,再判斷當前時間-$_SESSION(' time')是否小於600(10分鐘),若大於,提示登陸逾時,銷毀session;若小於,允許操作,並更新time變數值為目前值。

部分程式碼

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(部分)

<?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區分企業微信瀏覽器| 普通微信瀏覽器| 其他瀏覽器 

PHP二維數組根據某個元素去重

###################################

以上是php實現使用者登陸簡單的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn