视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
细说session和cookie会话控制
2020-11-27 19:59:51 责编:小采
文档

本篇文章讲述了session和cookie会话控制,大家对session和cookie会话控制不了解的话或者对session和cookie会话控制感兴趣的话那么我们就一起来看看本篇文章吧, 好了废话少说进入正题吧

对于一个前端开发者,cookie我想大家都不陌生,经常会封装一些诸如setcookie,getcookie的方法,session就好像一个最熟悉的陌生人一样,在我们与后端开发者合作项目的时候会用到它,但是不理解它的本质,下面我们就来详细探讨下

cookie

存储位置:存储于客户端
作用:本域跨页面存储数据(我们似乎一般都用来username,password)

cookie一般包含如下图的信息:

传输:下面是一条http请求报文

在每次发送请求中,cookie都会随着http报文发向后台

cookie和session的关系

session

下面我以php语言为用例,讲解session

从上面可以看出session存储于服务器端,而且以文件的形式存储
session有好多特性,比如过期时间等,下面我们查看,打开php.ini文件(里面有php的诸多配置信息,我去除了n多注释)

下面我看看具体看看那个sessionID

可以看出,这也就与上面那个session.name = “PHPSESSID”不谋而合

我们已经清楚了前台浏览器是如何携带sessionID传输到后台,以及后台存储session文件的位置,那后台具体利用sessionID分析利用呢, 我们接着分析

为了分析机制,请看下面php代码

<?php
 session_start();
 header("Content-Type: text/html;charset=utf-8"); 
 if ($_SESSION['username'] != 'success') {
 /* /php/index.php为当前文件路径 */
 $string = <<< EOF
 <form action="/php/index.php" method="post">
 <input type="text" name="value">
 <input type="submit">
 </form>
EOF;
 echo $string;
 }
 if ($_SESSION['username'] == 'success') {
 echo "登录成功".PHP_EOL;
 }
 if ($_POST['value'] == 'ys') {
 $_SESSION['username'] = 'success';
 echo "登录成功".PHP_EOL;
 }
?>

执行了php文件,体验session过程

发现http的cookie头部中的sessionID和服务器session文件名一样
这样就能根据每次请求的session找到唯一的session文件,然后看看这个文件是怎么样的

username|S:7:"success";s|S:7:"success";ss|S:7:"success";

这是这个文件的内容,里面有s,ss,username,其中s和ss就是我之前测试的名字(可以忽略),也就是这样

username|S:7:"success";

然后每次后台就能根据sessionID确定唯一会话,设置诸如$_SESSION[‘username’]之类的加以判断,实现cookie之间的通信。

相关推荐:

php之session和cookie总结分享

php会话控制session、cookie介绍

下载本文
显示全文
专题