专业3 Cookie 和Session的使用及原理
Cookie的使用及原理
什么是cookie
cookie是一种用来跟踪和识别用户上网信息的会话控制技术,它将跟踪后的信息存储在客户端的浏览器上
cookie如何使用
第一步:设置cookie即可(告诉浏览器,有cookie要存储值了)
setcookie('cookie的键名','cookie的值')
第二步:取出cookie的值,cookie的值可以使用PHP的超全局预定义数组$_COOKIE直接取即可
echo $_COOKIE['cookie的键名']
如果想要删除cookie
第一种:清除浏览器的缓存就能删除cookie了
第二种:代码删除
//给cookie重新设置过期时间,时间为过去时
setcookie("username","",time()-1);
cookie的分类
cookie分为会话cookie和持久cookie
会话cookie指:未给cookie设置过期时间,当浏览器关闭cookie的值就会消失
//会话cookie,未设置过期时间,当关闭浏览器,值就删除了
setcookie("username","root");
持久cookie值:给cookie设置过期时间,只有当过期时间到cookie的值才会消失
setcookie("username","root",time()+20);
session
Session的使用及原理 什么是session session也是一种和cookie一样的会话控制技术,它将跟踪后的信息以文件的形式存储在服务器端,所以说session相对于cookie而言更加安全 session如何使用 第一步:设置session,设置之前一定要使用session_start()开启session //开启session,在开启之前不允许有任何输出
session_start();
//设置session
$_SESSION['username']="admin";
第二步:取出session <h1>欢迎,
<font color="red">
<?php
//只要用的$_SESSION的地方,必须要先开启
session_start();
//输出键为username的值即可
echo $_SESSION['username']
?>
</font>登录
</h1>
删除session session_start();
//删除指定下标的session数据,同时session文件中的数据也会被删除掉
//unset($_SESSION['name']);
//清空session数组,同时将session文件销毁
session_destroy();
session的存储位置 session将跟踪和识别后的记录以文件的形式保存在服务器端,那么文件的保存位置由PHP的配置文件中的:session.save_path来决定 文件的存储名是一个32位的sessionID,如何得知哪个文件是你的存储的session数据呢,可以打印cookie数组来查看: print_r($_COOKIE);
//得到
Array(
'name' => 'admin',
'PHPSESSID' => 'gmf800he5068ns1apmkg865i26'
)
其中PHPSESSID指向的就是一个32位的随机数,简称sessionID
session的运行原理 当页面遇到session_start()时,服务器端会准备产生一个32位的sessionID,在产生前会先查看本地的cookie中是否存在,如果cookie中已有sessionID,那么session认为会话未结束,不再产生新的sessionID,接下来的操作依旧和上一个sessionID存储的文件进行关联。 如果本地的cookie中不存在sessionID则说明会话是一个新会话,此时服务器端会将产生的新sessionID发送一份寄存在本地的cookie,同时会创建一个以sessionID命名的文件来进行对会话内容存储。
如何让session不过期 通过原理我们发现,session是关闭浏览器后就消失的一种保存方式。 session的存储内容和sessionID
有关,如果能让sessionID持久保存,则服务器端不会在每次重新打开浏览器后遇到session_start()时生成新的sessionid了。
实现: //开启session
session_start();
//设置session
$_SESSION['name']="admin"; //让sessionid不过期
//session_name():获取sessionID的名称
//session_id():获取sessionID的值
//第三个参数就是给其增加上过期时间
setcookie(session_name(),session_id(),time()+60*24);
专业3 Cookie 和Session的使用及原理的更多相关文章
- 转:cookie和session(一)——原理
文章来自于:http://blog.csdn.net/half1/article/details/21645545 一.cookie和session是什么? cookie是服务器留在客户端中的小文 ...
- Flask中cookie和session设置与csrf原理攻防
Flask之操作cookie app.py from flask import Flask, request, Response app = Flask(__name__) @app.route('/ ...
- cookie和session的区别及其原理
1.为什么要有cookie/session? HTTP是一种无状态的协议,为了分辨链接是谁发起的,需自己去解决这个问题.不然有些情况下即使是同一个网站每打开一个页面也都要登录一下.而Session和C ...
- [转]cookie、session、sessionid 与jsessionid
cookie.session.sessionid 与jsessionid,要想明白他们之间的关系,下面来看个有趣的场景来帮你理解. 我们都知道银行,银行的收柜台每天要接待客户存款/取款业务,可以有几种 ...
- cookie、session、sessionid的区别
我们都知道银行,银行的收柜台每天要接待客户存款/取款业务,可以有几种方案: 1.凭借柜台职员的记忆,由收柜台职员来为每位顾客办理存款/取款业务,单凭职员的记忆力,要记到每位顾客的相貌,并迅速这个顾客当 ...
- cookie、session、sessionid ,jsessionid 的区别
本文是转载虫师博客的文章http://www.cnblogs.com/fnng/archive/2012/08/14/2637279.html cookie.session.sessionid 与js ...
- 前端Cookie与Session的区别
我们在实际生活中总会遇到这样的事情,我们一旦登录(首次输入用户名和密码)某个网站之后,当我们再次访问的时候(只要不关闭浏览器),无需再次登录.而当我们在这个网站浏览一段时间后,它会产生我们浏览的记录, ...
- 前端页面——Cookie与Session有什么区别
我们在实际生活中总会遇到这样的事情,我们一旦登录(首次输入用户名和密码)某个网站之后,当我们再次访问的时候(只要不关闭浏览器),无需再次登录.而当我们在这个网站浏览一段时间后,它会产生我们浏览的记录, ...
- Session与Cookie(自定义Session)
一.会话管理 会话管理: 管理浏览器客户端 和 服务器端之间会话过程中产生的会话数据. 域对象: 实现资源之间的数据共享. request域对象 context域对象 会话技术: Cookie技术:会 ...
随机推荐
- JS let, var, const的用法以及区别
本文摘自多位前辈的博文,另外还有一些我的多余补充,摘自地址已补充.非常感谢各位前辈.仅以笔记学习为目的! 深入学习ES6的知识还请访问阮一峰老师的ES6教程 如果不使用let或者const,在JS只有 ...
- element ui图片上传方法
<!--商品图片--> <template v-slot:product_cover> <el-upload list-type="picture-card&q ...
- Apache——配置与应用
Apache配置与应用 1.概述 2.httpd服务支持的虚拟主机类型 3.构建虚拟Web主机 4.构建Web虚拟目录与用户授权限制 5.日志分割 6.AWStats分析系统 1.概述: 虚拟web主 ...
- MySQL日志管理、备份与恢复
MySQL日志管理.备份与恢复 目录 MySQL日志管理.备份与恢复 一.MySQL日志管理 1. MySQL日志路径 2. 设置.修改日志路径 3. 查询日志功能是否开启 二.MySQL备份与恢复 ...
- shell脚本命令
http://man.linuxde.net/shell-script 从键盘或文件中获取标准输入:read命令 文件的描述符和重定向 数组.关联数组和别名的使用 函数的定义.执行.传参和递归函数 ...
- PCI Verilog IP
1 PCI IP设计 虽然PCI已经逐渐淘汰,但是还是有不少应用需要这样的接口通讯. 设计目的是为了提供基于源码的PCI IP,这样硬件就不必受限于某一个FPGA型号,也方便ASIC迁移.由 ...
- 基于TMS320C6670的软件无线电核心板
一.板卡概述 北京太速科技自主研发的TMS320C6670核心板,采用TI KeyStone系列的四核定点/浮点DSP TMS320C6670作主处理器.板卡引出处理器的全部信号引脚,便于客户二次开发 ...
- 用python的turtle作图(二)动画吃豆人
本文是用python的turtle作图的第二篇,通过这个例子可以了解动画的原理,用python自带的turtle库制作一些小动画. 1.问题描述 在上一篇"用python的turtle作图( ...
- shell脚本部署zookeeper-3.4.10 [含注释]
文章目录 zk_install.sh conf/config conf/zoo_template.cfg package zk_install.sh #!/bin/bash base_path=$(c ...
- etcd受损节点重新加入集群
文章目录 查看当前集群状态 删除受损etcd节点的数据 数据受损节点重新加入集群 修改etcd启动参数,重启etcd 由于自己的误操作,将A节点的etcd备份数据复制到B节点的etcd备份节点目录下, ...