科威网络做网站怎么样,汕头网站设计电话,哪些网站可以做招生,wordpress如何设置用户浏览权限1. ActionContext ActionContext是被存放在当前线程中的#xff0c;获取ActionContext也是从ThreadLocal中获取的。所以在执行拦截器、 action和result的过程中#xff0c;由于他们都是在一个线程中按照顺序执行的#xff0c;所以可以可以在任意时候在ThreadLocal中获取 Act… 1. ActionContext ActionContext是被存放在当前线程中的获取ActionContext也是从ThreadLocal中获取的。所以在执行拦截器、 action和result的过程中由于他们都是在一个线程中按照顺序执行的所以可以可以在任意时候在ThreadLocal中获取 ActionContext。 ActionContext包括了很多信息比如Session、Application、Request、Locale、ValueStack等其中 ValueStack可以解析ognl表达式来动态后去一些值同时可以给表达式提供对象。 ActionContext(com.opensymphony.xwork.ActionContext)是Action执行时的上下文,上下文可以看作是一个容器 (其实我们这里的容器就是一个Map而已),它存放的是Action在执行时需要用到的对象. 一般情况, 我们的ActionContext都是通过: ActionContext context (ActionContext) actionContext.get(); 来获取的.我们再来看看这里的actionContext对象的创建: static ThreadLocal actionContext new ActionContextThreadLocal(); ActionContextThreadLocal是实现ThreadLocal的一个内部类.ThreadLocal可以命名为线程局部变量,它为每一个使用该变量的线程都提供一个变量值的副本,使每一个线程都可以独立地改变自己的副本,而不会和其它线程的副本冲突.这样,我们 ActionContext里的属性只会在对应的当前请求线程中可见,从而保证它是线程安全的. 通过ActionContext取得HttpSession: Map session ActionContext.getContext().getSession(); (通过Map模拟HttpServlet的对象,操作更方便) 2. 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(); 3. ServletActionContext和ActionContext联系 ServletActionContext和ActionContext有着一些重复的功能,在我们的Action中,该如何去抉择呢?我们遵循的原则是:如果ActionContext能够实现我们的功能,那最好就不要使用ServletActionContext,让我们的Action尽量不要直接去访问Servlet的相关对象. 注意在使用ActionContext时有一点要注意: 不要在Action的构造函数里使用ActionContext.getContext(), 因为这个时候ActionContext里的一些值也许没有设置,这时通过ActionContext取得的值也许是null同样HttpServletRequest req ServletActionContext.getRequest()也不要放在构造函数中也不要直接将req作为类变量给其赋值。 至于原因我想是因为前面讲到的static ThreadLocal actionContext new ActionContextThreadLocal()从这里我们可以看出ActionContext是线程安全的而 ServletActionContext继承自ActionContext所以ServletActionContext也线程安全线程安全要求每个线程都独立进行所以req的创建也要求独立进行所以ServletActionContext.getRequest()这句话不要放在构造函数中也不要直接放在类中而应该放在每个具体的方法体中(eglogin()、queryAll()、insert()等)这样才能保证每次产生对象时独立的建立了一个req。 4.ActionContextClearUp ActionContextClearUp其实是Defer ClearUP.作用就是延长action中属性的生命周期包括自定义属性以便在jsp页面中进行访问让actionContextcleanup过滤器来清除属性不让action自己清除。具体看下面的代码代码很简单 public void doFilter(...){ ... try{ ... //继续执行所配置的chain中的Filter chain.doFilter(request, response); }finally{ //保证在所有动作执行完之后,调用cleanUp ... cleanUp(request); }
} protected static void cleanUp(ServletRequest req) { ...
ActionContext.setContext(null);//清除ActionContext实例 Dispatcher.setInstance(null);//清除Dispatcher实例(Dispatcher主要是完成将url解析成对应的Action)
}
另外注明一下UtilTimerStack的push和pop是用来计算调用方法所执行的开始和结束时间用来做性能测试的。用法如下String timerKey ActionContextCleanUp_doFilter: ; UtilTimerStack.setActive(true); UtilTimerStack.push(timerKey);
//调用要测试的方法。
UtilTimerStack.pop(timerKey);