ServletContext,ActionContext,ServletActionContext

ServletContext
ServletContext从他的package信息可以看出,它是标准的JavaEE WebApplication类库 javax.servlet.ServletContext.
ServletContext
提供了标准的Servlet运行环境,其实就是一些servlet和web container进行通信的方法:

public interface ServletContext {
public String getServletContextName();
public ServletContext getContext(String uri);
public String getContextPath();
public String getRealPath(String uri);atch

public RequestDispatcher getRequestDispatcher(String uri);
public RequestDispatcher getNamedDispatcher(String servletName);
public Object getAttribute(String name);
public Enumeration getAttributeNames();
pu
blic void setAttribute(String name, Object value);
public void removeAttribute(String name); }

注意:

一个ServletContext对应一个命名空间的servlet( 比如/struts下的所有servlet),是被所有servlet共享的。servletContext不同的是,一个Servlet对应一个servletConfig(不管有多少客户访问它从而开启了多少个线程),而servletContext是一个web工程只有一个servletContext

ServletContext被包含在ServletConfig对象中,ServletConfig对象在servlet容器初始化servlet时创建,存放servlet对象初始化的参数信息。用的最多的地方是,读取web.xml中的当前这个Servlet的初始化参数。通常被servlet或filter的init(ServletConfig config)方法调用。

例如web.xml中的配置
<servlet>
<servlet-name>BeerParamTests</servlet-name>
<servlet-class>TestInitParams</servlet-class>
<init-param>
<param-name>foo</param-name>
<param-value>bar</param-value>
</init-param>
</servlet>
那么在指定的servlet中用getServletConfig().getInitParameter(“foo”)取到bar的值。

ActionContext

ActionContext来源于Struts2 与 Struts1的本质不同.
struts1
时,由一个servlet (servlet org.apache.struts.action.ActionServlet)处理所有的*.do
struts2
时,由一个filter(org.apache.struts2.dispatcher.FilterDispatcher)处理所有的请求
struts1 仍旧属于servlet范畴,struts1 action 其本质仍是servlet.
struts2 action
已经是普通的java bean了,已经跳出了servlet 框架
ActionContext就是为了弥补strtus2 action跳出标准servlet框架而造成的和WEB环境失去联系的缺陷

ActionContext
的主要作用:
提供Web环境Context解决线程安全问题解决一些和其他框架或容器(siteMesh,webLogic)的兼容问题。

ServletActionContext

ServletActionContext(com.opensymphony.webwork.ServletActionContext),这个类直接继承了我们上面介绍的ActionContext,它提供了直接与Servlet相关对象访问的功能,它可以取得的对象有:

(1)javax.servlet.http.HttpServletRequest :HTTPservlet请求对象

(2)javax.servlet.http.HttpServletResponse :HTTPservlet相应对象

(3)javax.servlet.ServletContext : Servlet上下文信息

(4)javax.servlet.ServletConfig : Servlet配置对象

(5)javax.servlet.jsp.PageContext : Http页面上下文

如何从ServletActionContext里取得Servlet的相关对象:

<1>取得HttpServletRequest对象:HttpServletRequest request = ServletActionContext. getRequest();

<2>取得HttpSession对象:HttpSession session = ServletActionContext. getRequest().getSession();

、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、

以下转自http://blog.csdn.net/liuliulomo/article/details/6671756


ActionContext(Action上下文)
1、ActionContext介绍
  我们知道Xwork与Web无关性,我们的Action不用去依赖于任何Web容器,不用和那些JavaServlet复杂的请求(Request)、响应(Response)关联在一起。对请求(Request)的参数(Param),可以使用拦截器框架自动调用一些get()和set()方法设置到对应的Action的字段中。但是,仅仅取得请求参数的值就能完全满足我们的功能要求吗?不,在Web应用程序开发中,除了将请求参数自动设置到Action的字段中,我们往往也需要在Action里直接获取请求(Request)或会话(Session)的一些信息,甚至需要直接对JavaServlet Http的请求(HttpServletRequest)、响应(HttpServletResponse)操作。

  带着这些问题,我们来看看下面的一个功能需求:

  我们需要在Action中取得request请求参数“username”的值:

代码 ActionContext context = ActionContext.getContext();
Map params = context.getParameters();
String username = (String) params.get(“username”);

为了实现这个功能,我们用了三个步骤:

1、 取得我们当前的ActionContext对象context,ActionContext是个什么冬冬?

2、 从context对象里获取我们所有的请求参数,取得的却是一个Map对象params?

3、 居然可以从我们的Map对象params里获取我们需要的request请求参数“username”的值。

  ActionContext(com.opensymphony.xwork.ActionContext)是Action执行时的上下文,上下文可以看作是一个容器(其实我们这里的容器就是一个Map而已),它存放放的是Action在执行时需要用到的对象,比如:在使用WebWork时,我们的上下文放有请求的参数(Parameter)、会话(Session)、Servlet上下文(ServletContext)、本地化(Locale)信息等。

  在每次执行Action之前都会创建新的ActionContext,ActionContext是线程安全的,也就是说在同一个线程里ActionContext里的属性是唯一的,这样我的Action就可以在多线程中使用。

  我们可以通过ActionContext的静态方法:ActionContext.getContext()来取得当前的ActionContext对象,我们看看这段代码:


代码  public static ActionContext getContext() {
ActionContext context = (ActionContext) actionContext.get();

if (context == null) {
OgnlValueStack vs = new OgnlValueStack();
context = new ActionContext(vs.getContext());
setContext(context);
}

return context;
}

  一般情况,我们的ActionContext都是通过:ActionContext context = (ActionContext)actionContext.get();来获取的。我们再来看看这里的actionContext对象的创建:static ThreadLocalactionContext = newActionContextThreadLocal();,ActionContextThreadLocal是实现ThreadLocal的一个内部类。ThreadLocal可以命名为“线程局部变量”,它为每一个使用该变量的线程都提供一个变量值的副本,使每一个线程都可以独立地改变自己的副本,而不会和其它线程的副本冲突。这样,我们ActionContext里的属性只会在对应的当前请求线程中可见,从而保证它是线程安全的。

  下面我们看看怎么通过ActionContext取得我们的HttpSession:

  Map session = ActionContext.getContext().getSession();

  原来我们取得的session却是Map类型的对象,这是为什么?原来,我们的WebWork框架将与Web相关的很多对象重新进行了包装,比如这里就将HttpSession对象重新包装成了一个Map对象,供我们的Action使用,而不用直接和底层的HttpSession打交道。也正是框架的包装,让我们的Actoion可以完全的和Web层解藕。

  如果我们的Action需要直接与JavaServlet的HttpSession、HttpServletRequest等一些对象进行操作,我们又该如何处理?请看下面的ServletActionContext。

ServletActionContext

  ServletActionContext(com.opensymphony.webwork.ServletActionContext),这个类直接继承了我们上面介绍的ActionContext,它提供了直接与JavaServlet相关对象访问的功能,它可以取得的对象有:

1、 javax.servlet.http.HttpServletRequest:HTTPservlet请求对象

2、 javax.servlet.http.HttpServletResponse;:HTTPservlet相应对象

3、 javax.servlet.ServletContext:Servlet 上下文信息

4、 javax.servlet.ServletConfig:Servlet配置对象

5、 javax.servlet.jsp.PageContext:Http页面上下文

  ServletActionContext除了提供了上面这些对象访问,它当然也继承了它父类ActionContex的很多功能,比如:对OgnlValueStack、Action名字等的访问。

  下面我们看看几个简单的例子,让我们了解如何从ServletActionContext里取得JavaServlet的相关对象:

1、 取得HttpServletRequest对象:

HttpServletRequest request = ServletActionContext. getRequest();

2、 取得HttpSession对象:

HttpSession session = ServletActionContext. getRequest().getSession();

  ServletActionContext和ActionContext有着一些重复的功能,在我们的Action中,该如何去抉择呢?我们遵循的原则是:如果ActionContext能够实现我们的功能,那最好就不要使用ServletActionContext,让我们的Action尽量不要直接去访问JavaServlet的相关对象。在使用ActionContext时有一点要注意:不要在Action的构造函数里使用ActionContext.getContext(),因为这个时候ActionContext里的一些值也许没有设置,这时通过ActionContext取得的值也许是null。


对ActionContext和ServletActionContext总结
1、ActionContext指action执行时的上下文,上下文中存放一些请求的参数,servlet的上下文、会话和本地化的一些信息,我们可以通过getContext()获取这些信息。ServletActionContext是继承ActionContext,ServletActionContext除能获取这些信息外,还可以获取web容器的相关信息。
2、ActionContext是与web容器无关,它可以通过getContext().getParameters()获取请求的所有参数;而ServletActionContext与web容器有关,它可以通过getRequest(),getResponse()等获取请求的信息。
3、他们都是线程安全的,用实例池解决线程安全性。这也是区别struts1的一个特点,struts1是单例模式,所有请求都只有一个action。
4、如果ActionContext能够实现我们的功能,那最好就不要使用ServletActionContext,让我们的Action尽量不要直接去访问JavaServlet的相关对象。在使用ActionContext时有一点要注意:不要在Action的构造函数里使用ActionContext.getContext(),因为这个时候ActionContext里的一些值也许没有设置,这时通过ActionContext取得的值也许是null。


你可能感兴趣的:(servletContext,ActionContext)