当前位置:   article > 正文

PHP实现最简单的登录界面_编写程序用php实现一个登录界面

编写程序用php实现一个登录界面

PHP学习路上的第一个完整的极小极小的项目,总算是看着了做项目的希望了,特意做个记录

登录界面:

html代码(login.html):

  1. <form action="login.php" method="post">
  2. <fieldset>
  3. <legend>用户登录</legend>
  4. <ul>
  5. <li>
  6. <label>用户名:</label>
  7. <input type="text" name="username">
  8. </li>
  9. <li>
  10. <label>密   码:</label>
  11. <input type="password" name="password">
  12. </li>
  13. <li>
  14. <label> </label>
  15. <input type="checkbox" name="remember" value="yes">7天内自动登录
  16. </li>
  17. <li>
  18. <label> </label>
  19. <input type="submit" name="login" value="登录">
  20. </li>
  21. </ul>
  22. </fieldset>
  23. </form>

login.php:(登陆处理页)

  1. <?php
  2. header('Content-type:text/html; charset=utf-8');
  3. // 开启Session
  4. session_start();
  5. // 处理用户登录信息
  6. if (isset($_POST['login'])) {
  7. # 接收用户的登录信息
  8. $username = trim($_POST['username']);
  9. $password = trim($_POST['password']);
  10. // 判断提交的登录信息
  11. if (($username == '') || ($password == '')) {
  12. // 若为空,视为未填写,提示错误,并3秒后返回登录界面
  13. header('refresh:3; url=login.html');
  14. echo "用户名或密码不能为空,系统将在3秒后跳转到登录界面,请重新填写登录信息!";
  15. exit;
  16. } elseif (($username != 'username') || ($password != 'password')) {
  17. # 用户名或密码错误,同空的处理方式
  18. header('refresh:3; url=login.html');
  19. echo "用户名或密码错误,系统将在3秒后跳转到登录界面,请重新填写登录信息!";
  20. exit;
  21. } elseif (($username = 'username') && ($password = 'password')) {
  22. # 用户名和密码都正确,将用户信息存到Session中
  23. $_SESSION['username'] = $username;
  24. $_SESSION['islogin'] = 1;
  25. // 若勾选7天内自动登录,则将其保存到Cookie并设置保留7天
  26. if ($_POST['remember'] == "yes") {
  27. setcookie('username', $username, time()+7*24*60*60);
  28. setcookie('code', md5($username.md5($password)), time()+7*24*60*60);
  29. } else {
  30. // 没有勾选则删除Cookie
  31. setcookie('username', '', time()-999);
  32. setcookie('code', '', time()-999);
  33. }
  34. // 处理完附加项后跳转到登录成功的首页
  35. header('location:index.php');
  36. }
  37. }
  38. ?>

index.php(默认主页):

  1. <?php
  2. header('Content-type:text/html; charset=utf-8');
  3. // 开启Session
  4. session_start();
  5. // 首先判断Cookie是否有记住了用户信息
  6. if (isset($_COOKIE['username'])) {
  7. # 若记住了用户信息,则直接传给Session
  8. $_SESSION['username'] = $_COOKIE['username'];
  9. $_SESSION['islogin'] = 1;
  10. }
  11. if (isset($_SESSION['islogin'])) {
  12. // 若已经登录
  13. echo "你好! ".$_SESSION['username'].' ,欢迎来到个人中心!<br>';
  14. echo "<a href='logout.php'>注销</a>";
  15. } else {
  16. // 若没有登录
  17. echo "您还没有登录,请<a href='login.html'>登录</a>";
  18. }
  19. ?>

logout.php注销页

  1. <?php
  2. header('Content-type:text/html; charset=utf-8');
  3. // 注销后的操作
  4. session_start();
  5. // 清除Session
  6. $username = $_SESSION['username']; //用于后面的提示信息
  7. $_SESSION = array();
  8. session_destroy();
  9. // 清除Cookie
  10. setcookie('username', '', time()-99);
  11. setcookie('code', '', time()-99);
  12. // 提示信息
  13. echo "欢迎下次光临, ".$username.'<br>';
  14. echo "<a href='login.html'>重新登录</a>";
  15. ?>

登录成功的状态:


若勾选7天内自动登录,则会将登录信息通过Cookie和Session技术保存在本地Cookie文件中,7天内会自动登录。

注销页面:


登录错误的几种情况都做了处理:



本人是看的传智的教材加视频自学PHP,刚入门,第一个小小小小项目,大佬勿打击‘\抱拳’


声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/很楠不爱3/article/detail/708249
推荐阅读
相关标签
  

闽ICP备14008679号