解决HTTP的无状态问题

1、通过Cookies保存状态信息

Client
—————-请求1—————————>
<————–响应1 + set cookie————
—————-请求2 + cookie—————>
Server

通过Cookies,服务器就可以清楚的知道请求2和请求1来自同一个客户端。

2、通过Session保存状态信息

当程序需要为某个客户端的请求创建一个session的时候,服务器首先检查这个客户端的请求里是否已包含了一个session标识 - 称为 session id;
如果已包含一个session id则说明以前已经为此客户端创建过session,服务器就按照session id把这个 session检索出来使用(如果检索不到,可能会新建一个);
如果客户端请求不包含session id,则为此客户端创建一个session并且生成一个与此session相关联的session id,session id的值应该是一个既不会重复,又不容易被找到规律以仿造的字符串,这个session id将被在本次响应中通过Cookie返回给客户端保存。

3、Session和Cookie区别

  • Cookie将状态保存在客户端,Session将状态保存在服务器端;
  • Cookies是服务器在本地机器上存储的小段文本,并随每一个请求发送至同一个服务器。
    网络服务器用HTTP头向客户端发送cookies,在客户终端,浏览器解析这些cookies并将它们保存为一个本地文件,它会自动将同一服务器的任何请求缚上这些cookies。
  • Session是针对每一个用户的,变量的值保存在服务器上,用一个session id来区分是哪个用户session变量,这个值是通过用户浏览器在访问的时候返回给服务器,当客户禁用cookie时,这个值也可能设置为由get来返回给服务器;

你可能感兴趣的:(HTTP,http)