1.描述Cookie的作用

Cookie是网站保存在浏览器客户端的信息,也就是说保存在访客的机器里的变量,一般随着HTTP头发送到客户端。在Cookie生效之后及失效之前,客户每次发出页面请求的时候,都会把Cookie -块发送到服务器,只要我们针对它进行相应的处理,就可以改变它的值。

2.描述Session的作用

Session的中文译名叫做”会话”,其本来的含义是指有始有终的一系列动作/消息,比如用户在浏览某个网站时,从进入网站到浏览器关闭所经过的这段时间,也就是用户浏览这个网站所花费的时间。

3.Cookie和Session有什么区别?它们各自的应用范围是什么?

●  cookie数据存放在客户的浏览器上,session数据放在服务器上。

●  cookie不是很安全,别人可以分析存放在本地的Cookie并进行Coo kie欺骗,考虑到安全应当使用session。

●  session在一定时间内保存在服务器上。当访问增多,会比较占用服务器的资源。

●  考虑到提高服务器的性能,应当使用Cookie。

●  单个cookie保存的数据不能超过4K,很多浏览器Coo kie有数量限制。

●  将登录信息等重要信息存放为Session:其它信息如果需要保留,可以放在Cookie中。

4.Session的工作原理是什么?

Session机制是一种服务器端的机制,服务器使用一种类似于散列表的结构(也可能就是使用散列表)来保存信息。当程序需要为某个客户端的请求创建—个session时,服务器首先检查这个客户端的请求里是否已包含了—个session标识(称为session id),如果已包合则说明以前已经为此客户端创建过session,服务器就按照session id把这个session检索出来使用(检索不到,会新建—个),如果客户端请求不包含session id,则为此客户端创建—个session并且生成—个与此session相关联的session id,session id的值应该是—个既不会重复,又不容易被找到规律以仿造的字符串,这个session id将被在本次响应中返回给客户端保存。倮存这个session id的方式可以采用cookie,这样在交互过程中浏览器可以自动的按照规则把这个标识发送给服务器。—般这个cookie的名字都是类似于SEEESIONID。但cookie可以被人为的禁止,则必须有其他机制以便在cookie被禁止时仍然能够把session id传递回服务器。

5.Session如何存取?Session何时被创建?Session何时被删除?如何在关闭浏览器的时候删除Session?

通过HttpServletRequest对象的getSession0来获取session。

存储数据方式:session.setAttribute(”key”,value);

获取数据方式:session.getAttribute(”key”);

Session对象在调用HttpServletRequest.getSession(true)语句时被创建。

删除session:

调用HttpSession.invaldata()方法:

距离上一次收到客户端发送的session id时间间隔超过了session的超时设置。

关闭浏览器的时候删除session:

在页面中添加onunload事件,当关闭浏览器时,执行服务器端删除session代码。

优点:退出时,能及时进行处理。缺点:当用户打开多个页面时,关闭任何—个页面都有可能导致用户的退出。

6.什么是Session超时?如何修改默认的超时时间?

Session超时指的是: Web服务器会将空闲时间过长的Session对象删除掉,以节省服务器内存空间资源。web服务器缺省的超时时间限制:—般是30分钟。修改Session的缺省时间限制,有如下两种方式:

●  通过修改tomcat中conf/web.xml文件的设置,代码如下所示:

<session-config>

<session-timeout>30</session-timeout>

</session-config>

●  通过编程的方式来修改,通过调用Session对象的setMaxInactiveInterval方法来修改,该方法的声明如下所示:

void setMaxInactiveInterval(int seconds);

7.HttpSession session = request.getSession()与HttpSession session = request.getSession(true)的区别?getParameter与getAttribute的区别

●  HttpSession session = request.getSession()与HttpSession session = request.getSession(true)的区别如下:

HttpSession session = request.getSession(true)表示当参数为true时:先查看请求中有没有Sessionld,如果没有Sessionld,服务器创建—个Session对象:如果有Sessionld,依据Sessionld查找对应Session对象,找到则返回,找不到则创建—个新的Session对象,所以flag为true时,一定能得到—个Session对象;当flag为false时,没有Sessionld及有Sessionld但没有找到Session对象,均返回nu(七)找到则返回。HttpSession session = request.getSession0等价于HttpSession session=request.getSession(true),供该方法是为了代码书写更方便一些,大部分情况下是不管找没找到都需要返回一Session对象。

●  getParameter与getAttribute的区别如下:

request.getParameter()方法是获得客户端传送给服务器的参数值,代表http请求数据。由URL传入或由FORM提交的内容,返回值是String类型。request.getAttribute()属性值,数据在具有转发关系的Web组件之间共享,返回值为Object类型。

IT兄弟连 JavaWeb教程 Servlet会话跟踪 经典面试题的更多相关文章

  1. IT兄弟连 JavaWeb教程 Servlet会话跟踪 经典案例

    案例需求:编写一个servlet,可以向session中存放一个消息,再编写一个servlet可以从session取得session中存放的这个消息. 案例实现: package com.xdl.se ...

  2. IT兄弟连 JavaWeb教程 Servlet会话跟踪 Session常用方法

    ●  public Object getAttribute(String name) 该方法返回在该session会话中具有指定名称的对象,如果没有指定名称的对象,则返回null. ●  public ...

  3. IT兄弟连 JavaWeb教程 Servlet会话跟踪 Session技术

    Servlet提供了HttpSession接口,该接口提供了一种跨多个页面请求或访问网站时识别用户以及存储有关用户信息的方式. Servlet容器使用这个接口来创建一个HTTP客户端和HTTP服务器之 ...

  4. IT兄弟连 JavaWeb教程 Servlet会话跟踪 Cookie常用方法

    以下是在Servlet中操作Cookie时可使用的有用的方法列表 ●  public void setDomain(String pattern) 该方法设置cookie适用的域,例如 itxdl.c ...

  5. IT兄弟连 JavaWeb教程 Servlet会话跟踪 Cookie路径问题

    操作Cookie时,需要注意路径问题: 设置操作:任何路径都可以设置Cookie,但是有时我们也是用设置进行替换Cookie和删除Cookie(maxAge=0)! 替换:只能由完全相同的路径来操作! ...

  6. IT兄弟连 JavaWeb教程 Servlet会话跟踪 创建Cookie

    Tomcat作为Web服务器,对Cookie提供了良好的支持.那么,运行在Tomcat的Servlet该如何访问Cookie呢?幸运的是,Servlet无需直接和HTTP请求或响应中的原始Cookie ...

  7. IT兄弟连 JavaWeb教程 Servlet会话跟踪 Cookie技术原理

    Cookie使用HTTPHeader传递数据.Cookie机制定义了两种报头,Set-Cookie报头和Cookie报头.Set-Cookie报头包含于Web服务器的响应头(ResponseHeade ...

  8. IT兄弟连 JavaWeb教程 Servlet会话跟踪 Cookie技术简介

    Cookie的英文原意是“点心”,它是在客户端访问Web服务器时,服务器在客户端硬盘上存放的信息,好像是服务器送给客户的“点心”.服务器可以根据Cookie来跟踪客户状态,这对于需要区别客户的场合(如 ...

  9. IT兄弟连 JavaWeb教程 Servlet会话跟踪 Session优缺点

    ●  数据存储在服务器,安全. ●  session能保存Object类型数据,也就是说能存储任意数据. ●  可存储的数据大小,理论上是无限制的. ●  因为数据存储在服务器端,当用户比较多时,会占 ...

随机推荐

  1. 【BZOJ4476】[Jsoi2015]送礼物 分数规划+RMQ

    [BZOJ4476][Jsoi2015]送礼物 Description JYY和CX的结婚纪念日即将到来,JYY来到萌萌开的礼品店选购纪念礼物.萌萌的礼品店很神奇,所有出售的礼物都按照特定的顺序都排成 ...

  2. TControl,TWinControl和TGraphicControl的显示函数

    -------------------------- 显示隐藏刷新 -------------------------- TControl = class(TComponent)procedure S ...

  3. tornado安全应用之cookie

    目前大多数服务器判断用户是否登录一般通过session机制,Tornado 通过 set_secure_cookie 和 get_secure_cookie 方法直接支持了这种功能.原理类似于sess ...

  4. SCAU RP Test —— 因式分解与组合

    D  RP Test Time Limit:1000MS  Memory Limit:65535K 题型: 编程题   语言: 无限制 描述 LRC是SCAU_ACM校队的主席,职业生涯为校队作过很多 ...

  5. 渲染树render tree

    CSSOM树和DOM树连接在一起形成一个render tree,渲染树用来计算可见元素的布局并且作为将像素渲染到屏幕上的过程的输入. DOM树和CSSOM树连接在一起形成render tree . r ...

  6. SDOI2017 Round1 Day1 题解

    不知道有几个AK的,除了出题人SB搬了个BZOJ3779以外,应该没什么因素阻碍AK吧.要是SCOI考这套题多好. BZOJ4816 数字表格 SB反演,推出答案为$\prod_{i=1}^nf^{\ ...

  7. JUC包中的锁框架

    JUC包中的锁,包括:Lock接口,ReadWriteLock接口,LockSupport阻塞原语,Condition条件,AbstractOwnableSynchronizer/AbstractQu ...

  8. 【转】Oracle Freelist和HWM原理及性能优化

    文章转自:http://www.wzsky.net/html/Program/DataBase/74799.html 近期来,FreeList的重要作用逐渐为Oracle DBA所认识,网上也出现一些 ...

  9. Eclipse用Runnable JAR file方式打jar包,并用该jar包进行二次开发

    目录: 1.eclipse创建Java项目(带jar包的) 2. eclipse用Export的Runnable JAR file方式打jar包(带jar包的) 打jar包 1)class2json1 ...

  10. Markdown编写github README.md

    Markdown编写github README.md 一.在线编辑器StackEdit Markdown在线编辑器地址 中文:https://www.zybuluo.com/mdeditor 英文:h ...