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. DIV+CSS常见问题的14条原因分析

    当你在一个浏览器里面做好,在其他浏览器里面却完全不是那么回事情.  很多时候,我们就只是去修补下,或者利用各个浏览器对代码支持的不一致,进行针对各个浏览器进行不同的定义.  其实浏览器的不兼容,我们往 ...

  2. Linux-正则表达式学习(精)

    正则表达式30分钟入门教程 来园子之前写的一篇正则表达式教程,部分翻译自codeproject的The 30 Minute Regex Tutorial. 由于评论里有过长的URL,所以本页排版比较混 ...

  3. Python pip源,解决安装慢的问题

    经常在使用Python的时候需要安装各种模块,而pip是很强大的模块安装工具,但是由于国外官方pypi经常被墙,导致不可用,所以我们最好是将自己使用的pip源更换一下,这样就能解决被墙导致的装不上库的 ...

  4. html5 canvas 涂鸦画板

    html5 canvas 的涂鸦画板,可以加载图片进行涂鸦,也可以下载服务器使用的php上传的图片不能超过1M,只能是jpg或者png 格式的演示地址的服务器网速不怎么样,读取文件可能很慢,到达100 ...

  5. laravel基础课程---2、Laravel配置文件、路由及php artisan(php artisan是什么)

    laravel基础课程---2.Laravel配置文件.路由及php artisan(php artisan是什么) 一.总结 一句话总结: PHP工具匠:php artisan,其实本身就是一些PH ...

  6. html5--3.14 lable元素和label属性

    html5--3.14 lable元素和label属性 学习要点 掌握label元素的使用 掌握label属性的使用 lable元素 用来为 input 元素定义标注(标记),建立一个与之相关联的标签 ...

  7. [原创]Java开发如何在线打开Word文件

    此方案使用了PageOffice产品实现在线打开Word文档: 1. 首先从PageOffice官网下载产品开发包,http://www.zhuozhengsoft.com/dowm/ ,下载Page ...

  8. Snmp在Windows下的实现----WinSNMP编程原理

    在Windows 下实现SNMP协议的编程,可以采用Winsock接口,在161,162端口通过udp传送信息.在Windows 2000中,Microsoft已经封装了SNMP协议的实现,提供了一套 ...

  9. VS2008中使用JSONCPP方法小结

    Introduction JSON (JavaScript Object Notation) is a lightweight data-interchange format. It can repr ...

  10. rsync应用实例

      一. 通过ssh的方式 前面介绍的rsync 5种方式当中,第二.第三(1个冒号)就属于通过ssh的方式,这种方式其实就是让用户去登录到远程机器,然后执行rsync的任务. [root@local ...