千锋教育-做有情怀、有良心、有品质的职业教育机构

400-811-9990
手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

上海
  • 北京
  • 郑州
  • 武汉
  • 成都
  • 西安
  • 沈阳
  • 广州
  • 南京
  • 深圳
  • 大连
  • 青岛
  • 杭州
  • 重庆
当前位置:重庆千锋IT培训  >  技术干货  >  一文了解session的工作原理

一文了解session的工作原理

来源:千锋教育
发布人:lxl
时间: 2023-02-14 15:08:01

  首先session是我们在学习javaweb时很重要的一个技能点,在面试的时候经常被面试官问到,常见问题如下:

  1、session和Cookie的区别是什么?

  2、session的生命周期是怎样的?

  3、session的性能瓶颈?

  4、session的工作原理?

  ……

千锋教育

  今天就来和大家来剖析一下session的工作原理。

  特别说明一下,现在说的session是基于Cookie的session,如果客户端禁用Cookie的话,session的实现则不同,这个稍后进行解析。

  第一:当客户端浏览器窗口发出请求后,该浏览器的Cookie就会被传入服务器;

  第二:服务器读取Cookie中的sessionid,这时就存在读到和读不到两种情况

  第三:如果读不到,则由容器创建一个session,然后把这个session的sessionid用Cookie写入客户端

  第四:下次再进行网络请求时,这个sessionid也同样会被传入服务器

  第五:服务器读取到sessionid后,就到容器中查找到了该sessionid所对应的session

  综上所述,容器是根据sessionid来区分你的请求到底该使用哪个seesion的。

  刚刚提到,如果客户端禁用了Cookie,就不能使用Cookie在客户端浏览器和服务器间进行sessionid的传输了,那么该如何处理呢?这就需要对url进行重写了

  url重写其实就是把sessionid拼接在url的后面,通过url在客户端和服务器之间传输这个sessionid,只要客户端读取到了客户端传递过来的sessionid了,就可以查找到对应的session了。

  url重写使用 response.encodeRedirectURL("页面")

  接下来给大家来分析一下session和Cookie的区别:

  1、Cookie是存于客户端的,相对而言不够安全,而session是在服务器器上,相对比较安全

  2、Cookie只能存于字符串,而session可以存储对象

  3、两者的默认有效时间也不同。seesion的默认有效时间为30分钟,浏览器关闭,session也就失效

  而Cookie的有效期如果设置为0,则将Cookie删除,设置为负数的话,存于浏览器缓存里,浏览器关闭也就失效,设置为正数的话,单位为秒,设置多少就在多少秒内有效。

声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。

猜你喜欢LIKE

java的输入语句—— Scanner类

2023-05-04

java数据库操作常识事务的四大特性

2023-05-04

DML数据操作之增加或删除数据

2023-05-04

最新文章NEW

socket是什么?有什么作用?

2023-05-04

Java常量定义是什么

2023-04-28

一分钟带你学多线程

2023-04-28

相关推荐HOT

更多>>

快速通道 更多>>

最新开班信息 更多>>

网友热搜 更多>>