博客列表 >会话控制学习

会话控制学习

阿杰
阿杰原创
2022年07月09日 16:35:08479浏览

一、什么是会话

  1. // cookie:再客户端(浏览器)保存用户信息
  2. // 第一次访问一个php脚本文件
  3. // 那么这个php可以通过一个函数来给客户端设置cookie
  4. // 服务器识别用户,是通过用户使用的终端/浏览器来识别
  5. // 开启一个会话
  6. // session_start();
  7. /**
  8. * 执行两个动作
  9. * 1、浏览器:PHPSESSID,基于cookie
  10. * 2、服务器:创建一个与PHPSESSID同名的会话文件
  11. */
  12. // $_SESSION['email'] = 'admin@php.cn';
  13. // $_SESSION['password'] = md5(md5('123456').'php.cn888');
  14. // $_SESSION = [];
  15. // 直接将服务器上的会话文件删除
  16. // session_destroy();

二、会话实例

  • 用户登录、注册、退出登录流程
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <?php
  4. session_start(); //开启一个会话
  5. // 判断用户是否已经登录
  6. if(isset($_SESSION['user'])){
  7. // unserialize()函数需要处理序列化之后的字符串,然后将其反序列化为php的值
  8. $user = unserialize($_SESSION['user']);
  9. }
  10. ?>
  11. <head>
  12. <meta charset="UTF-8">
  13. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  14. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  15. <title>session</title>
  16. </head>
  17. <body>
  18. <nav>
  19. <?php if(isset($user)) : ?>
  20. <a href="" id="logout">退出</a>
  21. <?php else : ?>
  22. <a href="login.php">登录</a>
  23. <?php endif ?>
  24. </nav>
  25. <script>
  26. document.querySelector('#logout').addEventListener('click', function(event) {
  27. if (confirm('是否退出?')) {
  28. // 禁用默认跳转行为
  29. event.preventDefault();
  30. // 跳转到处理器
  31. location.assign('handle.php?action=logout');
  32. }
  33. });
  34. </script>
  35. </body>
  36. </html>

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <?php
  4. session_start();
  5. // 判断用户是否已经登录
  6. if(isset($_SESSION['user'])){
  7. echo '<script>alert("不要重复登录");location.href="index.php"</script>';
  8. }
  9. ?>
  10. <head>
  11. <meta charset="UTF-8">
  12. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  13. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  14. <title>登录</title>
  15. </head>
  16. <body>
  17. <form action="handle.php?action=login" method="post">
  18. <fieldset>
  19. <legend>用户登录</legend>
  20. <p>
  21. <input type="email" name="email" placeholder="user@email.com" require>
  22. </p>
  23. <p>
  24. <input type="password" name="password" placeholder="不少于6位" require>
  25. </p>
  26. <p>
  27. <button>提交</button>
  28. </p>
  29. </fieldset>
  30. <a href="register.php">如果没有账号,请先注册</a>
  31. </form>
  32. </body>
  33. </html>

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <?php
  4. session_start();
  5. // 判断用户是否已经登录
  6. if(isset($_SESSION['user'])){
  7. echo '<script>alert("不要重复登录");location.href="index.php"</script>';
  8. }
  9. ?>
  10. <head>
  11. <meta charset="UTF-8">
  12. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  13. <meta name="viewport" content="width=], initial-scale=1.0">
  14. <title>注册</title>
  15. </head>
  16. <body>
  17. <form action="handle.php?action=register" method="post">
  18. <fieldset>
  19. <legend>用户注册</legend>
  20. <p>
  21. <input type="text" name="name" placeholder="请输入" require>
  22. </p>
  23. <p>
  24. <input type="email" name="email" placeholder="user@email.com" require>
  25. </p>
  26. <p>
  27. <input type="password" name="password" placeholder="不少于6位" require>
  28. </p>
  29. <p>
  30. <button>提交</button>
  31. </p>
  32. </fieldset>
  33. </form>
  34. </body>
  35. </html>

声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议