怎样解析Cookie和Session
今天就跟大家聊聊有关怎样解析Cookie和Session,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
1.Cookie概念
当用户使用浏览器首次访问一个支持Cookie的网站的时候,用户会提供包括用户名在内的个人信息发送到服务器;
接着服务器端接收到客户端发送过来的http请求后,会发送一个http响应到客户端,其中包含Set-Cookie头部,自此,客户端再向服务器发送请求的时候,都会把相应的Cookie再次发回至服务器,服务器在接收到来自客户端浏览器的请求之后,就能够通过分析存放于请求头的Cookie得到客户端特有的信息,从而动态生成与该客户端相对应的内容;
在客户端的第二次请求中包含的Cookie头部中,提供给了服务器端可以用来唯一标识客户端身份的信息。这时,服务器端也就可以判断客户端是否启用了cookies
在客户端的第二次请求中包含的Cookie头部中,提供给了服务器端可以用来唯一标识客户端身份的信息。这时,服务器端也就可以判断客户端是否启用了cookies,查看浏览器中的Cookie信息
2.为什么要使用Cookie
Web应用程序是使用HTTP协议传输数据的,但是HTTP协议是无状态的协议,也就是说一旦数据交换完毕,客户端与服务器端的连接就会关闭,再次交换数据需要建立新的连接;
这就意味着服务器无法从连接上跟踪会话,如果想要踪该会话,必须引入一种机制,Cookie就是这样的一种机制,它可以弥补HTTP协议无状态的不足,在Session出现之前基本上所有的网站都采用Cookie来跟踪会话;
3.Cookie管理机制
Cookie具有不可跨域名性,根据Cookie规范,浏览器访问一个域名时只会携带此域名的Cookie,而不会携带其他域名的Cookie;
Cookie在客户端是由浏览器来管理的,浏览器能够保证域名不跨域,从而保证用户的隐私安全,浏览器判断一个网站是否能操作另一个网站Cookie的依据是域名;
让浏览器禁用Cookie,这样当再次访问登录过的网页时需要重新登录,
4.Cookie的属性介绍
name
:名称,Cookie一旦创建,名称便不可更改;value
:值,如果值为Unicode字符,需要为字符编码maxAge
:Cookie失效的时间,单位秒,默认为-1。如果为正数则该Cookie在在超过maxAge秒之后失效。如果为负数则Cookie为临时Cookie,关闭浏览器即失效,浏览器也不会以任何形式保存该Cookie。如果为0,表示删除该Cookie。secure
:Cookie是否仅被使用安全协议(HTTPS,SSL等)传输;path
:Cookie的使用路径,如果设置为“/sessionWeb/”,则只有contextPath为“/sessionWeb”的程序可以访问该Cookie。如果设置为“/”,则本域名下contextPath都可以访问该Cookie。注意最后一个字符必须为“/”;String domain
:可以访问该Cookie的域名,如果设置为“.9xkd.com”,则所有以“9xkd.com”结尾的域名都可以访问该Cookie。注意第一个字符必须为“.”;
5.Session概念
Session是服务器端使用的一种记录客户端状态的机制,使用上比Cookie简单一些,相应的也增加了服务器的存储压力;
Session技术则是服务端的解决方案,它是通过服务器来保持状态的,我们通常都会把Session翻译成会话,因此我们可以把客户端浏览器与服务器之间一系列交互的动作称为一个 Session;
6.使用Session
第一步是创建Session,Session是在服务器端程序运行的过程中创建的,不同语言实现的应用程序有不同创建Session的方法,在创建了Session的同时,服务器会为该Session生成唯一的Session id,而这个Session id在随后的请求中会被用来重新获得已经创建的Session;
然后可以调用Session相关的方法往Session中增加内容,这些内容只会保存在服务器中,发到客户端的只有Session id;
当客户端再次发送请求的时候,会将这个Session id带上,服务器接受到请求之后就会依据Session id找到相应的Session,从而再次使用,这样用户的状态也就得以保持了;
7.Cookie与Session的区别
cookie数据存放在客户的浏览器上,session数据存放在服务器上;
cookie没有Session安全,别人可以分析存放在本地的Cookie并进行Cookie欺骗,考虑到安全应当使用session;
session会在一定时间内保存在服务器上,当访问增多,会比较占用服务器的性能,考虑到减轻服务器性能方面,应当使用Cookie;
服务端的session的实现对客户端的cookie有依赖关系的,sessionid是写在cookie中的;
看完上述内容,你们对怎样解析Cookie和Session有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注编程网行业资讯频道,感谢大家的支持。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341