PHPでユーザーログインを実装する簡単な方法

墨辰丷
リリース: 2023-03-27 18:50:01
オリジナル
1862 人が閲覧しました

この記事では主にphpでのユーザーログインの簡単な例に関する関連情報を紹介します。必要な方は参考にしてください

phpでのユーザーログインの簡単な例

前書き:

最後の部分は最近完成予定です。ユーザーが送信したデータの管理については、ログイン、アカウントの権限、アカウントの有効期限の確認などを行う必要があります。

必要な知識

セッションは確かに非常に重要です。そして、セッションがページをまたぐことができないことが判明したので、PHP.ini の session.use_trans_sid = 0 の値を 1 に変更しました。

具体的な実装

私のバックエンドの設計は比較的シンプルです。もちろん、このパスワードはサーバーに保存されており、変更することができます。したがって、フラグと時間という 2 つの変数をセッションに追加するだけで済みます。

まず、管理者が正常にログインしたかどうかをフラグを使用して判断し、ログインがタイムアウトしたかどうかを時間を使用して判断します。パスワードを送信した後、それが正しければ、フラグには値 1 が割り当てられ、時刻には現在の時刻が割り当てられます。新しいページに入るたび、または操作を実行するたびに、これら 2 つの変数が判定されます。まず、フラグの値が 1 であるかどうかを判定します。一意でない場合は、ログインしていないことを直接通知し、セッションを破棄します。 1 の場合、現在の時刻 -$_SESSION(' time') が 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 (部分)

<?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 特定の要素に基づく二次元配列の重複排除

以上がPHPでユーザーログインを実装する簡単な方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!