public class LoginAction1 extends ActionSupport {
private Map request;
private Map session;
private Map application;
public LoginAction1() {
request = (Map)ActionContext.getContext().get( " request " );
session = ActionContext.getContext().getSession();
application = ActionContext.getContext().getApplication();
}
public String execute() {
request.put( " r1 " , " request1 " );
session.put( " s1 " , " session1 " );
application.put( " a1 " , " application1 " );
return SUCCESS;
}
}
// 第二种 几乎都用这种方式
public class LoginAction2 extends ActionSupport implements RequestAware,SessionAware, ApplicationAware {
private Map < String, Object > request;
private Map < String, Object > session;
private Map < String, Object > application;
// DI dependency injection
// IoC inverse of control
public String execute() {
request.put( " r1 " , " r1 " );
session.put( " s1 " , " s1 " );
application.put( " a1 " , " a1 " );
return SUCCESS;
}
@Override
public void setRequest(Map < String, Object > request) {
this .request = request;
}
@Override
public void setSession(Map < String, Object > session) {
this .session = session;
}
@Override
public void setApplication(Map < String, Object > application) {
this .application = application;
}
}
// 第三种 很少用
public class LoginAction3 extends ActionSupport {
private HttpServletRequest request;
private HttpSession session;
private ServletContext application;
public LoginAction3() {
request = ServletActionContext.getRequest();
session = request.getSession();
application = session.getServletContext();
}
public String execute() {
request.setAttribute( " r1 " , " r1 " );
session.setAttribute( " s1 " , " s1 " );
application.setAttribute( " a1 " , " a1 " );
return SUCCESS;
}
}
// 第四种 很少用
public class LoginAction4 extends ActionSupport implements ServletRequestAware {
private HttpServletRequest request;
private HttpSession session;
private ServletContext application;
public String execute() {
request.setAttribute( " r1 " , " r1 " );
session.setAttribute( " s1 " , " s1 " );
application.setAttribute( " a1 " , " a1 " );
return SUCCESS;
}
@Override
public void setServletRequest(HttpServletRequest request) {
this .request = request;
this .session = request.getSession();
this .application = session.getServletContext();
}
}
jsp页面获取request/session/application中的值
2 < s:property value ="#session.s1" /> | <% = session.getAttribute( " s1 " ) %> < br />
3 < s:property value ="#application.a1" /> | <% = application.getAttribute( " a1 " ) %> < br />
4 < s:property value ="#attr.a1" />< br />
5 < s:property value ="#attr.s1" />< br />
6 < s:property value ="#attr.r1" />< br />
一下是我看到的一篇讲的比较详细的文章:
在Struts1.*中,要想访问request、response以及session等Servlet对象是很方便的,因为它们一直是作为形参在各个方法之间进行传递的,而在Struts2中我们就很难看到它们的芳踪了,因为我们获得表单中的值都是通过预先设置好了的get方法来得到的,那么如果有些参数我们必须通过request.getParametre或者session.getAttribute来得到,那么应该怎么做呢?按照Max的教程上的说法,可以分为两种:IoC方式和非IoC方式,如何理解这两种方式的区别呢?IoC是Spring里面的特征之一,字面意思是反转控制,说白了就是依赖注入,比方说类A依赖类B,那么就主动的给A注入一个类B的对象,下面看一下这两种方法的具体实现。
1.非Ioc方式
这种方式主要是利用了com.opensymphony.xwork2.ActionContext类以及org.apache.struts2.ServletActionContext类,具体的方法如下所示。
获得request对象:
- HttpServletRequest request = ServletActionContext.getRequest ();
- ActionContext ct= ActionContext.getContext()
- HttpServletRequest request=
- (HttpServletRequest)ct.get(ServletActionContext.HTTP_REQUEST);
获得session对象:
在Struts2中底层的session都被封装成了Map类型,我们称之为SessionMap,而平常我们所说的session则是指HttpSession对象,具体的获得方法如下所示。
- Map session=ActionContext.getSession();
- Map session=(Map)ActionContext.getContext().getActionContext.SESSION);
得到这个SessionMap之后我们就可以对session进行读写了,如果我们想得到原始的HttpSession可以首先得到HttpServletRequest对象,然后通过request.getSession()来取得原始的HttpSession对象。一般情况下SessionMap已经可以完成所有的工作,我们不必再去碰底层的session了。
2.IoC方式
这种方式相对来说变化就比较少了,具体流程如下所示。
获得request对象:
第一步:让action实现ServletRequestAware接口
第二步:在action中声明一个HttpServletRequest类型的实例变量
第三步:在action中实现ServletRequestAware接口的setServletRequest方法,实现方式很简单,如下所示。
private HttpServletRequest request;
public void setServletRequest(HttpServletRequest request) {
this.request = request;
}
获得Session对象(注意,此时的session是SessionMap类型):
第一步:让action实现SessionAware接口
第二步:在action中声明一个HttpServletRequest类型的实例变量
第三步:在action中实现SessionAware接口的setSession方法,实现方式很简单,如下所示。
private Map session;
publicvoid setSession(Map session) {
this. session = session;
}
以下是另一篇关于得到Request和Session的文章:
- 在Struts2里,如果需要在Action中使用session,可以通过下面两种方式得到
- 1.通过ActionContext class中的方法getSession得到
- 2.Action实现org.apache.struts2.interceptor.SessionAware接口的方式来对session进行操作
- 下面先看一个采用第一种方式,在action中得到session的例子
- package s2.ex.action;
- import java.util.Map;
- import com.opensymphony.xwork2.ActionContext;
- import com.opensymphony.xwork2.ActionSupport;
- public class SessionTestAction extends ActionSupport {
- public String execute() {
- ActionContext actionContext = ActionContext.getContext();
- Map session = actionContext.getSession();
- session.put("USER_NAME", "Test User");
- return SUCCESS;
- }
- }
- 在这个例子中,通过ActionContext得到session,并往session里放置一个key为USER_NAME,值为Test User的内容。
- 下面是一个实现org.apache.struts2.interceptor.SessionAware接口来对session操作的例子
- package s2.ex.action;
- import java.util.Map;
- import org.apache.struts2.interceptor.SessionAware;
- import com.opensymphony.xwork2.ActionSupport;
- public class SessionTest1Action extends ActionSupport implementsSessionAware {
- private Map session;
- public void setSession(Map session) {
- this.session = session;
- }
- public String execute() {
- this.session.put("USER_NAME", "Test User 1");
- return SUCCESS;
- }
- }
- 在这个例子中实现了接口SessionAware中的setSession方法。
- 上面两种方式都可以得到session,能实现的功能都是一样的。
- 这里推荐通过第二种方式来使用session,原因是便于做单体测试,用第二种方式,只需要构造一个Map就可以对action class进行单体测试了。
- 在一个项目中可能会有很多action都需要用到session,如果每个action都来实现org.apache.struts2.interceptor.SessionAware这个接口,可能会显得比较麻烦,所以建议作一个抽象的BaseAction类来实现org.apache.struts2.interceptor.SessionAware接口,以后所有的action只要继承这个BaseAction就可以了。
- 下面是一个如何在JSP中使用session的例子。
- <%@ page contentType="text/html; charset=UTF-8" %>
- <%@page pageEncoding="utf-8" %>
- <%@taglib prefix="s" uri="/struts-tags" %>
- <html>
- <head>
- <title>Session Test</title>
- </head>
- <body>
- <h1><s:property value="#session.USER_NAME"/></h1>
- <h1></h1>
- </body>
- </html>