网站地图    收藏   

主页 > php专栏 > php会话 >

php cookie登录验证代码 - php会话

来源:自学PHP网    时间:2014-11-27 20:45 作者: 阅读:

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

php cookie登录验证代码

提供一款可以自动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. ?> 

自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号-1@版权所有www.zixuephp.com

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

添加评论