Scholer
2015-04-30 17:27:10 +08:00
一个完善的session机制如下:
服务器生成一个id作为会话的id,同时可以已这个id为基础存储一些数据,整个session的id和数据可以存在文件里,也可以存在数据库里(PHP的session机制默认是存储文件)。
服务器把session的id和数据经过整理、加密等一系类过程作为一个数据(字符串)发送给客户端(浏览器),客户端将这个session存储下来。存储的方式可能有多种,最常用的是cookie(也可以是别的方式,只要保证在自己的web程序中可以取到,比如存在一个form标签里也是可以的)。
客户端(浏览器)发送请求时,带上session数据(大多时候是cookie)一起送给服务器,服务器通过解析这段数据来判断请求来自哪里,已经在这次会话的过程中存储的一些数据(后端)。
session和cookie的关系
cookie是一种存储机制,指的是web服务可以在客户端存储一小段数据。当某个web服务在客户端存储有cookie数据的时候,客户端可以在之后的每次请求中都带上这段数据(浏览器是会自动带上这段数据的)。当然客户端也完全可以选择不带上这段数据,浏览器也可以禁用cookie。
session与cookie的关系在于:在绝大多数的情况下,我们会默认使用cookie来存储session会话的数据,而且现在浏览器都实现了带cookie请求的方式,再加上PHP的session机制,我们不需要考虑怎么去设计并维护一个简单的session会话。
一些网站也会在cookie被禁用的情况下通过其它方式维护session。