热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

php中cookie与session应用学习笔记

在php中cookie与session的区别在于cookie数据保存在客户端,session数据保存在服务器端了,自然在使用方法上会有些细节上的区别了,但后面

在php中COOKIE与session的区别在于COOKIE数据保存在客户端,session数据保存在服务器端了,自然在使用方法上会有些细节上的区别了,但后面比前者要安全得多。

1.COOKIE&session简介和区别

COOKIE数据保存在客户端,session数据保存在服务器端。

简单的说,当你登录一个网站的时候,如果web服务器端使用的是session,那么所有的数据都保存在服务器上面,客户端每次请求服务器的时候会发送 当前会话的sessionid,服务器根据当前sessionid判断相应的用户数据标志,以确定用户是否登录,或具有某种权限。由于数据是存储在服务器 上面,所以你不能伪造,但是如果你能够获取某个登录用户的sessionid,用特殊的浏览器伪造该用户的请求也是能够成功的。sessionid是服务器和客户端链接时候随机分配的,一般来说是不会有重复,但如果有大量的并发请求,也不是没有重复的可能性,我曾经就遇到过一次。登录某个网站,开始显示的 是自己的信息,等一段时间超时了,一刷新,居然显示了别人的信息。

如果浏览器使用的是 COOKIE,那么所有的数据都保存在浏览器端,比如你登录以后,服务器设置了 COOKIE用户名(username),那么,当你再次请求服务器的时候,浏览器会将username一块发送给服务器,这些变量有一定的特殊标记。服 务器会解释为 COOKIE变量。所以只要不关闭浏览器,那么 COOKIE变量便一直是有效的,所以能够保证长时间不掉线。如果你能够截获某个用户的 COOKIE变量,然后伪造一个数据包发送过去,那么服务器还是认为你是合法的。所以,使用 COOKIE被攻击的可能性比较大。如果设置了的有效时间,那么它会将 COOKIE保存在客户端的硬盘上,下次再访问该网站的时候,浏览器先检查有没有 COOKIE,如果有的话,就读取该 COOKIE,然后发送给服务器。如果你在机器上面保存了某个论坛 COOKIE,有效期是一年,如果有人入侵你的机器,将你的  COOKIE拷走,然后放在他的浏览器的目录下面,那么他登录该网站的时候就是用你的的身份登录的。所以 COOKIE是可以伪造的。当然,伪造的时候需要主意,直接copy   COOKIE文件到 COOKIE目录,浏览器是不认的,他有一个index.dat文件,存储了 COOKIE文件的建立时间,以及是否有修改,所以你必须先要有该网站的 COOKIE文件,并且要从保证时间上骗过浏览器,曾经在学校的vbb论坛上面做过试验,copy别人的 COOKIE登录,冒用了别人的名义发帖子,完全没有问题。

Session是由应用服务器维持的一个服务器端的存储空间,用户在连接服务器时,会由服务器生成一个唯一的SessionID,用该SessionID 为标识符来存取服务器端的Session存储空间。而SessionID这一数据则是保存到客户端,用COOKIE保存的,用户提交页面时,会将这一 SessionID提交到服务器端,来存取Session数据。这一过程,是不用开发人员干预的。所以一旦客户端禁用COOKIE,那么Session也会失效。

服务器也可以通过URL重写的方式来传递SessionID的值,因此不是完全依赖COOKIE。如果客户端COOKIE禁用,则服务器可以自动通过重写URL的方式来保存Session的值,并且这个过程对程序员透明。

可以试一下,即使不写COOKIE,在使用request.getCOOKIEs();取出的COOKIE数组的长度也是1,而这个COOKIE的名字就是JSESSIONID,还有一个很长的二进制的字符串,是SessionID的值。

2.COOKIE的配置与应用

基本语法:setCOOKIE("COOKIE", "COOKIEvalue", time()+3600, "/forum", ".xxx.com", 1);

名字 值  有效时间,毫秒   路径     保存域    是否使用https

访问和处理COOKIE

访问基本语法,代码如下:

  1. echo $myCOOKIE
  2. echo $COOKIEarray['0']; 
  3. echo $_COOKIE['myCOOKIE'];   (推荐) 
  4. echo $HTTP_COOKIE_VARS['myCOOKIE']; 

删除COOKIE

删除基本语法,代码如下:

  1. setCOOKIE("COOKIE","");   (用空COOKIE覆盖原值) 
  2. setCOOKIE("COOKIE""value", time()-1/time());   (时间销毁) 

实例代码如下:

  1. if ($_POST['user'] && $_POST['password']) { 
  2.  setCOOKIE("us"$_POST['user']); 
  3.  setCOOKIE("pwd"$_POST['password']); 
  4.  echo "用户:".$_COOKIE['us'].""."密码:".$_COOKIE['pwd']; 
  5. ?> 
  6. "form1" name="form1" method="post" action="file.php"
  7.    用户:"text" name="user" /> 
  8.     
  9.    密码:"text" name="password" /> 
  10.    "submit" name="Submit" value="提交" /> 
  11.  

注意:在输出之前必须操作完COOKIE,否则error。

1.session的配置与应用

基本语法,代码如下:

  1. session_start();   //初始化,必须放在文件头。 
  2. $_SESSION['name'] = value;   //配置session。 
  3. echo $_SESSION['name'];   //使用session。 
  4. isset($_SESSION['name']);   //判断。 
  5. unset($_SESSION['name']);   //删除。 
  6. session_destroy();   //销毁所有session。 

举一些实例来介绍session与COOKIE上的区别

<一>:session

启动session:session_start();

总结:该函数需要放在文件最前端,前面不要有任何输出,最好顶头写(不要有前导空格).

设置session:$_SESSION[&#39;name&#39;]=&#39;value&#39;;

总结:在使用的时候,直接使用$_SESSION[]方法设置值,其中"[ ]"部分为session的name,"="后面为值.

读取session:echo $_SESSION[&#39;name&#39;];

总结:不论是设置session还是读取session都要先开启session(使用session_start()).

销毁session:

1.关闭浏览器,自动销毁.

2.直接给 $_SESSION[]=&#39;&#39;; 清空.

<二>:COOKIE

设置COOKIE:

bool setCOOKIE(string name[,string value[,int expire[,string path[,string domain[,bool secure[,bool httponly]]]]]] )

name:   COOKIE变量名

value:   COOKIE变量的值

expire:  有效期结束的时间,

path:    有效目录,

domain: 有效域名,顶级域唯一

secure:  如果值为1,则COOKIE只能在https连接上有效,如果为默认值0,则http和https都可以.

例如:setCOOKIE(&#39;username&#39;,&#39;hello&#39;,time()+3600);         

setCOOKIE("username",&#39;hello&#39;,time()+3600,"/~rasmus/",".paea.cn",1);

总结:setCOOKIE前不能出现输出数据操作,否则就会出现错误类似于session_start().

读取COOKIE:

echo $_COOKIE[&#39;username&#39;].&#39;||&#39;;

echo $HTTP_COOKIE_VARS["username"];

总结:两种输出方式.

销毁COOKIE:设置一个过去的时间来注销COOKIE

setCOOKIE(&#39;username&#39;,&#39;hello&#39;,time()-3600);

总结:setCOOKIE前不能出现输出数据操作,否则就会出现错误类似于session_start().

总结一下

作用:session和COOKIE都是用于暂时记录用户数据的方式.

区别:

1.SESSION存储在服务器端,用户无法进行修改,比较安全,COOKIE存储在客户端,用户可以进行修改,不安全。

2.Session会在一定时间内保存在服务器上,会占用服务器资源。COOKIE存储在用户windows下的Temp目录中的。

3.单个COOKIE在客户端的限制是4k

4.session遍历使用$_SESSION[] ,COOKIE遍历使用$_COOKIE[]

5.禁用过COOKIE后session无法使用

6.session使用的时候要加session_start()并且前面不能有任何输出.


推荐阅读
  • CentOS 7部署KVM虚拟化环境之一架构介绍
    本文介绍了CentOS 7部署KVM虚拟化环境的架构,详细解释了虚拟化技术的概念和原理,包括全虚拟化和半虚拟化。同时介绍了虚拟机的概念和虚拟化软件的作用。 ... [详细]
  • 如何在服务器主机上实现文件共享的方法和工具
    本文介绍了在服务器主机上实现文件共享的方法和工具,包括Linux主机和Windows主机的文件传输方式,Web运维和FTP/SFTP客户端运维两种方式,以及使用WinSCP工具将文件上传至Linux云服务器的操作方法。此外,还介绍了在迁移过程中需要安装迁移Agent并输入目的端服务器所在华为云的AK/SK,以及主机迁移服务会收集的源端服务器信息。 ... [详细]
  • 如何提高PHP编程技能及推荐高级教程
    本文介绍了如何提高PHP编程技能的方法,推荐了一些高级教程。学习任何一种编程语言都需要长期的坚持和不懈的努力,本文提醒读者要有足够的耐心和时间投入。通过实践操作学习,可以更好地理解和掌握PHP语言的特异性,特别是单引号和双引号的用法。同时,本文也指出了只走马观花看整体而不深入学习的学习方式无法真正掌握这门语言,建议读者要从整体来考虑局部,培养大局观。最后,本文提醒读者完成一个像模像样的网站需要付出更多的努力和实践。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • 禁止程序接收鼠标事件的工具_VNC Viewer for Mac(远程桌面工具)免费版
    VNCViewerforMac是一款运行在Mac平台上的远程桌面工具,vncviewermac版可以帮助您使用Mac的键盘和鼠标来控制远程计算机,操作简 ... [详细]
  • 本文详细介绍了云服务器API接口的概念和作用,以及如何使用API接口管理云上资源和开发应用程序。通过创建实例API、调整实例配置API、关闭实例API和退还实例API等功能,可以实现云服务器的创建、配置修改和销毁等操作。对于想要学习云服务器API接口的人来说,本文提供了详细的入门指南和使用方法。如果想进一步了解相关知识或阅读更多相关文章,请关注编程笔记行业资讯频道。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 本文介绍了通过ABAP开发往外网发邮件的需求,并提供了配置和代码整理的资料。其中包括了配置SAP邮件服务器的步骤和ABAP写发送邮件代码的过程。通过RZ10配置参数和icm/server_port_1的设定,可以实现向Sap User和外部邮件发送邮件的功能。希望对需要的开发人员有帮助。摘要长度:184字。 ... [详细]
  • PDF内容编辑的两种小方法,你知道怎么操作吗?
    本文介绍了两种PDF内容编辑的方法:迅捷PDF编辑器和Adobe Acrobat DC。使用迅捷PDF编辑器,用户可以通过选择需要更改的文字内容并设置字体形式、大小和颜色来编辑PDF文件。而使用Adobe Acrobat DC,则可以通过在软件中点击编辑来编辑PDF文件。PDF文件的编辑可以帮助办公人员进行文件内容的修改和定制。 ... [详细]
  • 服务器上的操作系统有哪些,如何选择适合的操作系统?
    本文介绍了服务器上常见的操作系统,包括系统盘镜像、数据盘镜像和整机镜像的数量。同时,还介绍了共享镜像的限制和使用方法。此外,还提供了关于华为云服务的帮助中心,其中包括产品简介、价格说明、购买指南、用户指南、API参考、最佳实践、常见问题和视频帮助等技术文档。对于裸金属服务器的远程登录,本文介绍了使用密钥对登录的方法,并提供了部分操作系统配置示例。最后,还提到了SUSE云耀云服务器的特点和快速搭建方法。 ... [详细]
  • MySQL中的MVVC多版本并发控制机制的应用及实现
    本文介绍了MySQL中MVCC的应用及实现机制。MVCC是一种提高并发性能的技术,通过对事务内读取的内存进行处理,避免写操作堵塞读操作的并发问题。与其他数据库系统的MVCC实现机制不尽相同,MySQL的MVCC是在undolog中实现的。通过undolog可以找回数据的历史版本,提供给用户读取或在回滚时覆盖数据页上的数据。MySQL的大多数事务型存储引擎都实现了MVCC,但各自的实现机制有所不同。 ... [详细]
author-avatar
手机用户2502934787
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有