面试题:cook和session
1、首先,Cookie与Session存在的目的是什么?
答:二者都是为了保持客户端访问用户与后台服务器的交互状态,之所以为了保持这种状态,一是为了方便一些业务的实现,另一方面就是为了简化后台服务端的程序设计,提高性能。
2、如何理解Cookie?
答:我理解的Cookie,就是服务器端用来区分访问用户的,一个用户发出HTTP请求,服务端判断这个用户是不是第一次访问,如果是新用户,那么就得先登记,然后把这个用户的一些信息用Key-Value键值对的形式保存起来,通过HTTP响应让用户带回客户端,让用户保存着,下次访问时,捎带着把信息也带过来,一看是老熟人,后台就不用登记直接处理业务了,方便而有效率。
3、如何理解Session?
答:Cookie是保存在客户端的,而客户端保存Cookie是有数量和大小限制的,那我们就想,服务器端信息是可以保存很多很多的,这就有了Session。
我们在新客户访问时,就可以把信息登记然后保存在服务器,给用户一个唯一的信息标识就好了(一般是一个NAME为JSESSIONID的Cookie),下次用户访问的时候,只需要出示信息标识,后台就可以把他其他信息全部取出来(也就是把Session取出来),然后进行业务就好,防止了信息的篡改丢失等问题,而且没有容量限制。
4、Session如何基于Cookie工作?
答:刚刚说道对Session的理解时,提到一个Session的标识(一般是一个NAME为JSESSIONID的Cookie),这个标识一般是用Cookie保存在客户端用来维持Session的,但这是Cookie允许被使用的情况,如果Cookie被禁用,将会默认使用URL Parameter实现。
具体实现流程:
a、客户端第一次发出请求,因为服务端并不知道Cookie是否可用,所以服务端准备一个测试用的NAME为JSESSIONID的Cookie作为客户Session的标识,并将HTTP响应中的URL参数改写,在尾部加上JSESSIONID,返回响应。
b、客户端再次发出请求时,就会包含Cookie是否可用的信息,如果可用,则优先使用Cookie保存JSESSIONID,并会覆盖URL中的ID,如不可用,就用URL Parameter改写的方式实现JSESSIONID的传递,以维持Session。
c、当浏览器关闭或Session过期后,Cookie也就失效了。
5、如何配置SessionCookieName?
答:默认的SessionCookieName就是JSESSIONID,我们可以在web.xml中配置session-config项,其中cookie-config下的name属性就是这个SessionCookieName,可以由用户自己定义。
6、Session如何工作?
答:在通过问题4中的方法获得Session标识后,就可以通过request.getSession()获得HttpSession对象了,如果这个Session标识没有对应HttpSession时,那么就创建一个新的。
那么由谁管理HttpSession对象?
表面上,所有的HttpSession就会被加入到org.apache.catalina.Manager的sessions容器中保存,这个Manager类会管理所有Session的生命周期。Session过期了会被回收。
更具体的是,StandardManager是Manager的实现类,对应的,StandardSession是HttpSession的实现类;StandardManager类负责Servlet容器中所有StandardSession对象的生命周期的管理。
如果Session没有过期,而服务器关闭了,Session还会存在吗?
只要是正常关闭服务器,在关闭之前,StandardManager会把所有没有过期的StandardSession持久化到一个名为“SESSION.ser”的文件中,当Servlet重启时,StandardManager初始化,会重新读取这个文件解析出所有Session对象,重新保存在StandardManager中的sessions集合中,session恢复。
但是,当非正常关闭服务器时,是没有时间持久化Session的,就会导致Session丢失。
7、Cookie与Session有何缺陷?
任何事情都有两面性,他们的存在也带来了一些挑战,如Cookie的容量问题(大小、数量限制)、安全问题(易被篡改)、Session的服务器共享问题。
面试题:cook和session的更多相关文章
- 【面试题】了解session和cookie吗?
问题:SESSION与COOKIE的区别? 1.cookie数据存放在客户的浏览器上,session数据放在服务器上. 2.cookie不是很安全,别人可以分析存放在本地的COOKIE并进行COOKI ...
- .NET面试题(三)
第1讲:面试前期准备 1.了解相关技术职务需要的技术人才 2.准备一份出色的个人简历 第2讲:面试前期准备 ...
- smarty练习:考试系统
考试系统 (0607) 做一个类似于驾校考试的系统,可以选择要考试试题类型,选好后进入考试页面 使用的数据库表格:timu(题目)表,xuanxiang(选项)表,shiti(试题)表,shititi ...
- Requests模块 HTTP for Humans
安装方式 $ pip install requests 基本GET请求(headers参数 和 parmas参数) 1.最基本的GET请求可以直接用get方法 response = requests. ...
- Python爬虫十六式 - 第三式:Requests的用法
Requests: 让 HTTP 服务人类 学习一时爽,一直学习一直爽 Hello,大家好,我是Connor,一个从无到有的技术小白.今天我们继续来说我们的 Python 爬虫,上一次我们说到了 ...
- 面试题:servlet jsp cook session 背1
一.Servlet是什么?JSP是什么?它们的联系与区别是什么? Servlet是Java编写的运行在Servlet容器的服务端程序,狭义的Servlet是指Servlet接口,广义的Servlet是 ...
- php面试题12(多态web服务器共享session的方法:将session存到数据库)($val=&$data[$key];)
php面试题12(多态web服务器共享session的方法:将session存到数据库)($val=&$data[$key];) 一.总结 1.多态web服务器共享session的方法: ...
- Session对象的生命周期(面试题/笔试题)
创建:第一次执行request.getSession()时创建 销毁: 1)服务器(非正常)关闭时 2)session过期/失效(默认30分钟) 问题:时间的起算点 从何时开始计算30分钟? 从不操作 ...
- php开发面试题---禁用cookie之后,如何使用session
php开发面试题---禁用cookie之后,如何使用session 一.总结 一句话总结: 在每个url后面自动加上PHPSESSID的值即可,用户禁止cookie后,服务器仍会将sessionId以 ...
随机推荐
- PTA L3-023 计算图 (dfs+数学推导)
“计算图”(computational graph)是现代深度学习系统的基础执行引擎,提供了一种表示任意数学表达式的方法,例如用有向无环图表示的神经网络. 图中的节点表示基本操作或输入变量,边表示节点 ...
- Storm开发过程中的问题与建议
转自:http://blog.csdn.net/ouyang111222/article/details/50061305 (一) topology层级建议设不要设置过多 storm讲究是流式计算,s ...
- 排序算法总结(C#版)
算法质量的衡量标准: 1:时间复杂度:分析关键字比较次数和记录的移动次数: 2:空间复杂度:需要的辅助内存: 3:稳定性:相同的关键字计算后,次序是否不变. 简单排序方法 .直接插入排序 直接插入排序 ...
- [BZOJ5133][CodePlus2017年12月]白金元首与独舞
bzoj luogu 题意 给你一个\(n*m\)的网格,每个位置上有一个箭头指向上或下或左或右.有些位置上还没有箭头,现在要求你在这些没有箭头的位置上填入箭头,使得从网格的任意一个位置开始,都可以沿 ...
- LeetCode Design TinyURL
原题链接在这里:https://leetcode.com/problems/design-tinyurl/description/ 题目: How would you design a URL sho ...
- 转载 eclipse中的include设置
备注:在10.1版的niosii使用的eclipse中设置的方法是右键->properties->c/c++general->path and symbols->include ...
- Shell编程(二)——shell的基础知识及常用命令
shell的基础知识 一.bash有以下特点: 1.记录命令历史 2.指令和文件名补全 3.别名 alias rm='rm -i' 4.通配符 * 0个或多个字符 ?匹配一个字符 5 输入输出重定向 ...
- predis的使用
predis是PHP连接Redis的操作库,由于它完全使用php编写,大量使用命名空间以及闭包等功能,只支持php5.3以上版本,故实测性能一般,每秒25000次读写. 将session数据存放到re ...
- php与JAVA的RSA加密互通
Java 版本RSA 进行加密解密 在网上查询了好几天,最终找到解决方案,网络上都是通过Cipher.getInstance("RSA"); 而改成Cipher.getInstan ...
- bzoj 1415 [Noi2005]聪聪和可可——其实无环的图上概率
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1415 乍一看和“游走”一样.于是高斯消元.n^2状态,复杂度n^6…… 看看TJ,发现因为聪 ...