关于会话缓存的一些问题

1.session的工做流程php

  • 客户端访问服务器,服务器调用Session()方法,产生session对象,用于跟踪用户的状态
  • 同时,给session对象分配一个惟一标识sessionId。为了管理session对象,以sessionId为键,以session对象为值。
  • 产生响应时,将sessionId以cookie方式发送给客户端,存放在客户端浏览器的缓存中Cookie(JSESSIONID)
  • 当客户端再次请求服务器,会将sessionId以cookie请求头的方式发送给服务器(JSESSIONID),服务器获得JSESSIONID后和SessionID匹配,获得session对象,从而跟踪状态。【客户端】JSESSIONID =【服务端】 SessionID

2.cookie是怎么工做的html

  • 客户端访问服务器,服务器调用Cookie()方法,产生响应时,会产生set-cookie响应头
  • 将cookie文本发送给客户端,客户端会将cookie文本保存起来
  • 当客户端再次请求服务器时,会产生cookie请求头,将以前服务器发送的cookie信息,再发送给服务器,服务器就能够根据cookie信息跟踪客户端的状态。

3.cookie的文件形式数据库

  • Cookie 就是浏览器储存在用户电脑上的一小段文本文件
  • Cookie 是纯文本格式,不包含任何可执行的代码
  • Cookie 由键值对构成,由分号和空格隔开
  • Cookie 虽然是存储在浏览器,可是一般由服务器端进行设置
  • Cookie 的大小限制在 4kb 左右

4.cookie的具体内容跨域

    它能够记录你的用户ID、密码、浏览过的网页、停留的时间等信息。当你再次来到该网站时,网站经过读取Cookies,得知你的相关信息,就能够作出相应的动做,如在页面显示欢迎你的标语,或者让你不用输入ID、密码就直接登陆等等。一个网站只能读取它本身放置的信息,不能读取其余网站的Cookie文件。所以,Cookie文件还保存了host属性,即网站的域名或ip。 
    这些属性以名值对的方式进行保存,为了安全,它的内容大多进行了加密处理。Cookie文件的命名格式是:用户名@网站地址[数字].txt浏览器

5.cookie的优势和缺点缓存

Cookie的优势:安全

  1. 给用户更人性化的使用体验,如记住“密码功能”、老用户登陆欢迎语
  2. 弥补了HTTP无链接特性
  3. 站点统计访问人数的一个依据

 

Cookie的缺点:服务器

  1. 它没法解决多人共用一台电脑的问题,带来了不安全因素
  2. Cookie文件容易被误删除
  3. 一人使用多台电脑
  4. Cookies欺骗。修改host文件,能够非法访问目标站点的Cookie

6.禁用了cookie以后,session还能用吗?cookie

    Cookie与 Session,通常认为是两个独立的东西,Session采用的是在服务器端保持状态的方案,而Cookie采用的是在客户端保持状态的方案。但为何禁用Cookie就不能获得Session呢?由于Session是用Session ID来肯定当前对话所对应的服务器Session,而Session ID是经过Cookie来传递的,禁用Cookie至关于失去了Session ID,也就得不到Session了。网络

    在PHP中,经过相关的配置,可让Session不依赖Cookie而存在。PHP中的Session在默认状况下是使用客户端的Cookie来保存Session ID的,因此当客户端的cookie出现问题的时候就会影响Session了。必须注意的是:Session不必定必须依赖Cookie,这也是Session相比Cookie的高明之处。

    因此,咱们能够抛开Cookie使用Session,即假定用户关闭Cookie的状况下使用Session,其实现途径有如下几种:

        关闭cookie,使用session的方法

       1. 设置php.ini配置文件中的“session.use_trans_sid = 1”,或者编译时打开打开了“--enable-trans-sid”选项,让PHP自动跨页传递Session ID。
       2. 手动经过URL传值、隐藏表单传递Session ID。
       3. 用文件、数据库等形式保存Session ID,在跨页过程当中手动调用。


参考地址:https://www.cnblogs.com/tkzc2013/p/9875745.html

7.sessionid

 session的惟一标识,一个随机字符的字符串,例:sess_00nrqa20hjrlaiac0eu726i4q5

8.session和cookie的区别

 

一、存取方式的不一样

    Cookie中只能保管ASCII字符串,假如需求存取Unicode字符或者二进制数据,需求先进行编码。Cookie中也不能直接存取Java对象。若要存储略微复杂的信息,运用Cookie是比拟艰难的。

    而Session中可以存取任何类型的数据,包括而不限于String、Integer、List、Map等。Session中也可以直接保管Java Bean乃至任何Java类,对象等,运用起来十分便当。可以把Session看作是一个Java容器类。

二、隐私策略的不一样

    Cookie存储在客户端阅读器中,对客户端是可见的,客户端的一些程序可能会窥探、复制以致修正Cookie中的内容。而Session存储在服务器上,对客户端是透明的,不存在敏感信息泄露的风险。

    假如选用Cookie,比较好的方法是,敏感的信息如帐号密码等尽可能不要写到Cookie中。最好是像Google、Baidu那样将Cookie信息加密,提交到服务器后再进行解密,保证Cookie中的信息只要本人能读得懂。而假如选择Session就省事多了,反正是放在服务器上,Session里任何隐私都可以有效的保护。

三、有效期上的不一样

    使用过Google的人都晓得,假如登陆过Google,则Google的登陆信息长期有效。用户不用每次访问都从新登陆,Google会持久地记载该用户的登陆信息。要到达这种效果,运用Cookie会是比较好的选择。只须要设置Cookie的过时时间属性为一个很大很大的数字。

    因为Session依赖于名为JSESSIONID的Cookie,而Cookie JSESSIONID的过时时间默许为–1,只需关闭了阅读器该Session就会失效,于是Session不能完成信息永世有效的效果。运用URL地址重写也不能完成。并且假如设置Session的超时时间过长,服务器累计的Session就会越多,越容易招致内存溢出。

四、服务器压力的不一样 

    Session是保管在服务器端的,每一个用户都会产生一个Session。假如并发访问的用户十分多,会产生十分多的Session,耗费大量的内存。于是像Google、Baidu、Sina这样并发访问量极高的网站,是不太可能运用Session来追踪客户会话的。

    而Cookie保管在客户端,不占用服务器资源。假如并发阅读的用户十分多,Cookie是很好的选择。关于Google、Baidu、Sina来讲,Cookie或许是惟一的选择。

五、浏览器支持的不一样 

    Cookie是须要客户端浏览器支持的。假如客户端禁用了Cookie,或者不支持Cookie,则会话跟踪会失效。关于WAP上的应用,常规的Cookie就派不上用场了。

    假如客户端浏览器不支持Cookie,须要运用Session以及URL地址重写。须要注意的是一切的用到Session程序的URL都要进行URL地址重写,不然Session会话跟踪还会失效。关于WAP应用来讲,Session+URL地址重写或许是它惟一的选择。

    假如客户端支持Cookie,则Cookie既可以设为本浏览器窗口以及子窗口内有效(把过时时间设为–1),也可以设为一切阅读器窗口内有效(把过时时间设为某个大于0的整数)。但Session只能在本阅读器窗口以及其子窗口内有效。假如两个浏览器窗口互不相干,它们将运用两个不一样的Session。(IE8下不一样窗口Session相干)

六、跨域支持上的不一样

    Cookie支持跨域名访问,例如将domain属性设置为“.biaodianfu.com”,则以“.biaodianfu.com”为后缀的一切域名均可以访问该Cookie。跨域名Cookie现在被广泛用在网络中,例如Google、Baidu、Sina等。而Session则不会支持跨域名访问。Session仅在他所在的域名内有效。

    仅运用Cookie或者仅运用Session可能完成不了理想的效果。这时应该尝试一下同时运用Cookie与Session。Cookie与Session的搭配运用在实践项目中会完成不少意想不到的效果。

参考地址:https://zhinan.sogou.com/guide/number/316513843800.htm?rcer=uXdGqt9h59jxEs6th

相关文章
相关标签/搜索