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. 理解 React,但不理解 Redux,该如何通俗易懂的理解 Redux?

    作者:Wang Namelos链接:https://www.zhihu.com/question/41312576/answer/90782136来源:知乎著作权归作者所有.商业转载请联系作者获得授权 ...

  2. 阿里妈妈-RAP项目的实践(3)

    接下来,我们就把我们的代码运用到项目中,因为我们前台是有jquery,后台管理系统是用angularjs mock在这两种的调用方式不一样,所以我就用nginx的proxy_pass 来代理 我在项目 ...

  3. appium(8)-locator strategies

    locator strategies Finding and interacting with elements Appium supports a subset of the WebDriver l ...

  4. PAT天梯赛 L2-026. 小字辈 【BFS】

    题目链接 https://www.patest.cn/contests/gplt/L2-026 思路 用一个二维vector 来保存 每个人的子女 然后用BFS 广搜下去,当目前的状态 是搜完的时候 ...

  5. jmeter之java请求

    通常情况下,推荐使用jmeter之java请求编写一beashell调用java代码(上篇)(推荐)编写Java 请求 有以下优势 脚本易维护 易调试 开发脚本周期短 不过网上扩展java请求文章比较 ...

  6. ansible 文件模块,很实用

    摘自: http://blog.csdn.net/kellyseeme/article/details/50545521

  7. codeforces B. Ilya and Queries 解题报告

    题目链接:http://codeforces.com/problemset/problem/313/B 题目意思:给出一个只有 "."  和  "#" 组成的序 ...

  8. 使用XMLHttpRequest

    请求种类 通过XMLHttpRequest的请求可以通过同步和异步的方式获取数据,请求的种类在XMLHttpRequest的open()方法的第三三个可选参数async设置.如果这个参数是true或者 ...

  9. hdu-5776 sum(同余)

    题目链接: sum Time Limit: 2000/1000 MS (Java/Others)     Memory Limit: 131072/131072 K (Java/Others) Pro ...

  10. 记录一个读pcap数据包的软件:Fiddler

    Fiddler.大神推荐的.名字老忘. 用wireshark在wifi共享精灵共享出来的无线网上抓包,发现一个SSDP(简单服务发现协议)一直在尝试找连上这个网络上的设备. 连上NEXUS4后出现了I ...