返回首页
当前位置: 主页 > 网络编程 > Jsp实例教程 >

Servlet/JSP学习笔记Session和作用域

时间:2013-04-25 22:26来源:知行网www.zhixing123.cn 编辑:麦田守望者

几乎所有的Web开发语言都支持Session功能,Servlet也不例外。 Servlet/JSP中的Session功能是通过作用域(scope)这个概念来实现的。

作用域分为四种,分别为:

page 在当前页面有效(仅用于JSP中)
request 在当前请求中有效
session 在当前会话中有效
application 在所有应用程序中有效

 

是不是看不太明白?page因为仅用于JSP中,这里只讲述其他三种作用域。首先要声明的一点,所谓“作用域”就是“信息共享的范围”,也就是说一个信息能够在多大的范围内有效。

话说武松一日来到景阳岗,见一旗帜迎风飘扬,旗子上书五个大字“三碗不过岗”。武松叫道:“店家,拿三碗酒来,再切两斤熟牛肉!”店小二应声道:“三碗好酒,二斤熟牛肉啰~~”里面厨师赶忙当当当当切好牛肉,店小二倒上三碗酒,店小二端上前来。

武松咕咚咕咚连干三碗,叫一声“好酒!店家,再来三碗!”小二忙又倒上三碗好酒,武松一饮而尽。就这样前前后后武松一共喝了十八大腕。付了帐刚要走,店小二道: “客官,这前面山上有大虫,客官刚刚喝完十八碗酒恐怕过不得岗,不如在小店暂住一夜,待明天和猎户一同过岗岂不是好?”

之后武松说什么就留待各位看官自己去回忆啦。在这段武松打虎中,大家有没有看到些熟悉的东西?

  • 武松: 浏览器。
  • 酒馆: 服务器。
  • 店小二、厨师: Servlet或者JSP。
  • 来三碗好酒!: 浏览器向服务器发出HTTP请求。
  • 店小二上酒: 服务器的响应。
  • 武松从进店到离开: 一个HTTP对话。

我们可以看到,Web交互的最基本单位为HTTP请求(‘武松点菜‘)。每个用户从进入网站到离开网站这段过程称为一个HTTP会话 (‘武松进店到出店‘),一个服务器的运行过程中会有多个用户访问,就是多个HTTP会话(‘酒馆当然不可能只接待武松一个客人‘)。那么作用域就可以理解为:

request HTTP请求开始到结束这段时间
session HTTP会话开始到结束这段时间
application 服务器启动到停止这段时间

request

一个HTTP请求的处理可能需要多个Servlet合作(‘武松点菜时店小二就要吩咐厨房做菜‘),几个Servlet之间可以通过某种方式传递信息(‘店小二就用吆喝的方式通知厨房‘),但这个信息在请求结束后就无效了(‘厨房在做完菜之后就不用再管这道菜的事儿了‘)。

Servlet之间的信息共享是通过HttpServletRequest接口的两个方法来实现的:

void setAttribute(String name, Object value)
将对象 value 以 name 为名称保存到request作用域中。

Object getAttribute(String name)
从request作用域中取得指定名字的信息。

doGet()doPost()函数的第一个参数就是 HttpServletRequest 对象,使用这个对象的 setAttribute 即可传递信息。

那么设置好信息之后,如何将信息传给其他Servlet?这就要用到 RequestDispatcher 接口的 forward 方法,将请求转发给其他Servlet。

RequestDispatcher ServletContext.getRequestDispatcher(String path)
取得Dispatcher以便转发。path为转发的目的Servlet。

void RequestDispatcher.forward(ServletRequest request, ServletResponse response)
requestresponse转发。

因此,只要在当前Servlet中先 setAttribute,然后forward,最后在forward到的Servlet中 getAttribute即可实现信息传递。

PHP的程序员可能不太好理解这一段,因为PHP中没有转发的概念,一个请求只能由一个PHP文件来处理,所以PHP中根本没有request作用域的概念。而Servlet则不同,请求可以在应用程序中任意转发,所以用request作用域在不同Servlet之间传递信息。需要注意两点:

  1. 转发不是重定向,转发是在Web应用内部进行的。PHP支持重定向但没有转发。
  2. 转发对浏览器是透明的,也就是说,无论在服务器上如何转发,浏览器地址栏中显示的仍然是最初那个Servlet的地址。
------分隔线----------------------------
标签(Tag):Javascript javascript实例教程 JavaScript源代码 JavaScript基础教程
------分隔线----------------------------
推荐内容
猜你感兴趣