Maison >développement back-end >Problème PHP >Les utilisateurs PHP ne peuvent pas accéder à la page sans se connecter
Les utilisateurs PHP ne peuvent pas accéder à la page sans se connecter
Peu importe l'adresse du lien de page que vous saisissez avant de vous connecter , vous serez invité à vous connecter d'abord. Après une connexion réussie, chaque page est accessible. Comment implémenter une telle fonction ? Nous pouvons utiliser une session et un cookie pour y parvenir.
1. session
a) login.php
<?php header("content-type:text/html;charset=utf-8"); if(!isset($_POST['submit'])){ exit("非法登录"); } $name=trim($_POST['username']); //echo $name; $pwd=md5(trim($_POST['pwd'])); $pdo=new PDO("mysql:dbname=shixun1;host=127.0.0.1","root","123456"); if(preg_match('/^1[3,5,8]\d{9}$/',$name)) { $sql=$pdo->query("select phone,pwd from user where phone='$name'"); }elseif(preg_match('/^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$/',$name)){ $sql=$pdo->query("select email,pwd from user where email='$name'"); }else{ $sql=$pdo->query("select name,pwd from user where name='$name'"); } //$sql=$pdo->query("select * from user where name='$name'"); $res=$sql->fetch(PDO::FETCH_ASSOC); if($res){ if($res['pwd']==$pwd){ ini_set("session.save_handler", "memcache"); ini_set("session.save_path", "tcp://127.0.0.1:11211"); session_start(); $_SESSION['username'] = $name; $_SESSION['password'] = $pwd; echo "<script>alert('登录成功');location.href='success.php'</script>"; }else{ echo "<script>alert('密码错误');location.href='login.html'</script>"; } }else{ echo "<script>alert('用户名错误');location.href='login.html'</script>"; } ?>
b) checklogin.php
<?php if(!empty($_SESSION['username'])){ // 不存在session用户id,退出 echo "用户未登录,前往登录页面登录"; header("Location: login.php"); exit; } ?>
Chacun Le fichier doit être chargé au début de la page, vous devez donc vous connecter pour accéder à
2. Les cookies
sont faits avec des cookies L'idée est de vérifier. le cookie si l'enregistrement du cookie est Après la connexion, il ne sautera pas, sinon il passera à l'interface de connexion :
[Voici les informations à inclure sur chaque page]
<?php namespace PenguinStudio/PenguinCode/STDCode; if($_COOKIE['login_session'] !== "islogin"){ header("Location: login.php"); }
[Ce sont les informations sur l'interface de connexion]
<?php namespace PenguinStudio/PenguinCode/STDCode; if(.../* 判断登陆正确 */){ setcookie("login_session","islogin", time()+3600*24);//一天过期的cookie } else{ echo "<script>alert('wrong');</script>"; }
Pour plus de connaissances sur PHP, veuillez visiter le Site Web PHP chinois !
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!