当前位置:首页 > PHP教程 > php会话 > 列表

php cookie登录验证代码

发布:smiling 来源: PHP粉丝网  添加日期:2013-12-27 13:29:19 浏览: 评论:0 

提供一款可以自动cookie登录方法,用户可以在登录时选择保存进程几天几个月等,我们只要进来页面时判断一下就KO了。

html页面

  1. <html> 
  2. <head> 
  3. <title>Login</title> 
  4. <meta http-equiv="Content-Type" content="text/html; charset=gb2312"
  5. </head>  
  6. <body> 
  7. <form name="form1" method="post" action="login.php"
  8. <table width="300" border="0" align="center" cellpadding="2" cellspacing="2"
  9.     <tr> 
  10.       <td width="150"><div align="right">用户名:</div></td> 
  11.       <td width="150"><input type="text" name="username"></td> 
  12.     </tr> 
  13.     <tr> 
  14.       <td><div align="right">密码:</div></td> 
  15.       <td><input type="password" name="passcode"></td> 
  16.     </tr> 
  17.     <tr> 
  18.       <td><div align="right">Cookie保存时间:</div></td> 
  19.       <td><select name="cookie" id="cookie"
  20.         <option value="0" selected>浏览器进程</option> 
  21.         <option value="1">保存1天</option> 
  22.         <option value="2">保存30天</option> 
  23.         <option value="3">保存365天</option> 
  24.       </select></td> 
  25.     </tr> 
  26. </table> 
  27. <p align="center"
  28.     <input type="submit" name="Submit" value="Submit"
  29.     <input type="reset" name="Reset" value="Reset"
  30. </p> 
  31. </form> 
  32. </body> 
  33. </html> 

login.php

  1. <?php 
  2. @mysql_connect("localhost""root","1981427")     //选择数据库之前需要先连接数据库服务器 
  3. or die("数据库服务器连接失败"); 
  4. @mysql_select_db("test")      //选择数据库mydb 
  5. or die("数据库不存在或不可用"); 
  6. //获取用户输入 
  7. $username = $_POST['username']; 
  8. $passcode = $_POST['passcode']; 
  9. $cookie   = $_POST['cookie']; 
  10. //执行SQL语句 
  11. $query = @mysql_query("select username, userflag from users " 
  12. ."where username = '$username' and passcode = '$passcode'"
  13. or die("SQL语句执行失败"); 
  14. //判断用户是否存在,密码是否正确 
  15. if($row = mysql_fetch_array($query)) 
  16. if($row['userflag'] == 1 or $row['userflag'] == 0)    //判断用户权限信息是否有效 
  17.    switch($cookie)         //根据用户的选择设置cookie保存时间 
  18.    { 
  19.     case 0:         //保存Cookie为浏览器进程 
  20.      setcookie("username"$row['username']); 
  21.      break
  22.     case 1:         //保存1天 
  23.      setcookie("username"$row['username'], time()+24*60*60); 
  24.      break
  25.     case 2:         //保存30天 
  26.      setcookie("username"$row['username'], time()+30*24*60*60); 
  27.      break
  28.     case 3:         //保存365天 
  29.      setcookie("username"$row['username'], time()+365*24*60*60); 
  30.      break
  31.    } 
  32.    header("location: main.php");      //自动跳转到main.php 
  33. else 
  34.    echo "用户权限信息不正确"
  35. else 
  36. echo "用户名或密码错误"
  37. ?> 

main.php

  1. <?php 
  2. session_start(); 
  3. if(isset($_COOKIE['username'])) 
  4. @mysql_connect("localhost""root","1981427")     //选择数据库之前需要先连接数据库服务器 
  5. or die("数据库服务器连接失败"); 
  6. @mysql_select_db("test")      //选择数据库mydb 
  7. or die("数据库不存在或不可用"); 
  8. //获取Session 
  9. $username = $_COOKIE['username']; 
  10. //执行SQL语句获得userflag的值 
  11. $query = @mysql_query("select userflag from users " 
  12. ."where username = '$username'"
  13. or die("SQL语句执行失败"); 
  14. $row = mysql_fetch_array($query); 
  15. //获得用户权限信息 
  16. $flag = $row['userflag']; 
  17. //根据userflag的值输出不同的欢迎信息 
  18. if($flag == 1) 
  19.    echo "欢迎管理员".$_SESSION['username']."登录系统"
  20. if($flag == 0) 
  21.    echo "欢迎用户".$_SESSION['username']."登录系统"
  22. echo "<a href="logout.php" mce_href="logout.php">注销</a>"
  23. else 
  24. echo "您没有权限访问本页面"
  25. ?> 

logout.php

  1. <?php 
  2. setcookie("username"); 
  3. echo "注销成功"
  4. ?> 

Tags: cookie 登录 验证

分享到: