失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > 浅析PHP中cookie与session技术

浅析PHP中cookie与session技术

时间:2019-08-22 18:55:32

相关推荐

浅析PHP中cookie与session技术

php教程|php手册

技术

php教程-php手册

浅析PHP中cookie与session技术

维权网源码,ios能用ubuntu吗,爬虫陶瓷灯发红,php manu,菏泽seo推广lzw

1.cookie是什么?

cookie指某些网站为了辨别用户身份、进行session跟踪而储存在用户本地终端上的数据(通常经过加密)。

三公 源码,vscode中文编码,ubuntu查看启动项,tomcat 平滑,sqlite主键 索引,弹性云服务器怎么使用,手机搜索栏插件,前端流行框架,java爬虫工程师,自如php,在哪可以学seo,高仿上精品小屋网站,网页 json格式化插件下载,html 登陆 模板,让div在页面最上面显示,晶科物流管理系统v2.0,什么是控制台程序lzw

通俗来理解就是,你去一个专卖店或者超市买东西,然后店里给你办一张会员卡,以后你的身份和购买信息都存在这个卡里,而这个卡放你身上。之后每次去买东西的时候只需要刷卡就可以了,不用再登记或者记录其他的信息。

poscms最新版源码,ubuntu 热插拔硬盘,tomcat运行慢解决办法,爬虫体内驱虫,php输出换行符怎么用,seo网页标签lzw

然后将这段话映射了web上,超市结账台就是服务器端,而你自己就是客户端,你身上所带的卡也就是存在客户端中的cookie文件,里面记录了你的帐号密码等信息。

不过要注意的一点,cookie在第二次使用的时候才能够生效,也就是说你在超市第一次买东西,人家会给你办卡,你以后来买就可以刷卡了,但是第一次买之前,超市并没有你的任何信息,所以你第一次根本就没有卡。网站也一样,第一次登录某网站,当然要输入帐号密码等信息,然后才能生成cookie存在本地,以便下一次使用。

同时,cookie也有自己的有效期,过了期以后就失效了,本地的cookie文件会被自动删除。需要再次登录,输入帐号密码,然后生成新的cookie。这样做的主要目的还是为了安全考虑。

2.cookie机制图解。

3.cookie使用方法。

(1)设置cookie

bool setcookie ( string $name,$value,$expire,$path,$domain,$secure,$httponly

例如:

setcookie("username","user",0,"/");setcookie("username","user",time()+60*60,"/");

每个参数的用法就不作说明了。这里重点解析一下上面两中设置cookie方式中的时间和路径。

第一个当中的时间放了个0进去,难道代表生存时间为0.明显不可能,它有着特殊的意义,表示cookie的有效期随着浏览器的关闭而结束。他们的路径中都放了个”/”。这个就代表在这个域名下的所有contentpath都可以访问cookie,也就是说这个网站下的所有页面都可以追踪这个cookie。

(2)删除cookie

setcookie("username","",time()-3600,"/");

和设置cookie一个东西,就是没有了cookie的值,时间比当前时间还早,然后不就过期了。

(3)查看cookie

print_r($_COOKIE);

这家伙大家肯定都懂,就当浪费一下眼神。

———————————————————————————-

—————————–我是分割线——————————————-

———————————————————————————-

1.session是什么?

Session是指一个终端用户与交互系统进行通信的时间间隔,通常指从注册进入系统到注销退出系统之间所经过的时间。

session的工作原理(摘于百度)

(1)当一个session第一次被启用时,一个唯一的标识被存储于本地的cookie中。

(2)首先使用session_start()函数,PHP从session仓库中加载已经存储的session变量。

(3)当执行PHP脚本时,通过使用session_register()函数注册session变量。

(4)当PHP脚本执行结束时,未被销毁的session变量会被自动保存在本地一定路径下的session库中,这个路径可以通过php.ini文件中的session.save_path指定,下次浏览网页时可以加载使用。

其实通俗来讲的话,就是你去超市买东西,办的会员卡记录了你的信息,但是会员卡并不是保存在你这里,而是已数据的方式存在超市的系统中,一旦注册之后可以直接使用。你需要的时候,直接可以使用。但是你一旦离开超市,那个会员卡也就失去了效用直到你的下一次购买。同时,这个会员卡的唯一标识也就是你自己,其他任何人都没有办法使用你的会员卡。直接对号入座就很好理解了。

session和cookie的一大不同点就是,session注册之后直接使用,也就是第一次购买就可以使用,而cookie是经过第一次购买之后才将信息存入会员卡,然后第二次开始使用。

2.session机制图解。

3.session使用方法。

(1)设置session

session_start();

$_SESSION[username]="user";

每一次在使用session之前都需要进行开启session,就当是通常进门都先需要开门一样。而在设置session时和对变量进行赋值没有多大的区别,其实$_SESSION本身就是一个变量。

(2)删除session

这个相对步骤就多了点,而不是cookie里面一句话搞定。

//开启sessionsession_start();//注销sessionsession_unset();//销毁sessionsession_destroy();//同时销毁本地cookie中的sessionidsetcookie(session_name(),"",time()-3600,"/");

(3)查看session

print_r($_SESSION);

1.cookie与session优缺点。

cookie本身是存放在客户端中,仅占用几kb的内存大小。每次登录网站的时候都会带上本地的cookie进行验证,省去了麻烦的重复输入。但是安全性不是很高,毕竟是存放在本地的文件,虽然都是进行加密了的,一旦电脑数据被盗取,cookie就很有可能会被获取。

session存放在服务器中,占中内存虽小,但是用户基数够大的情况下,会对服务器造成很大的负荷。但是,数据放在服务器上,总归风险降低了许多。虽说没有不透风的墙,不过风也是可以很小很小的,这比喻。。。有同学可能疑问,session使用时,会有sessionid存在本地,一旦获取能否登录。答案当然是否定的,因为每次的id都是不一样的。

如果觉得《浅析PHP中cookie与session技术》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。