action中的幾種寫法
//第一種很少用
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中的值
1 <s:property value="#request.r1"/> | <%=request.getAttribute("r1") %> <br />
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 />
一下是我看到的一篇講的比較詳細(xì)的文章:
在Struts1.*中,要想訪問request、response以及session等Servlet對象是很方便的,因?yàn)樗鼈円恢笔亲鳛樾螀⒃诟鱾€方法之間進(jìn)行傳遞的,而在Struts2中我們就很難看到它們的芳蹤了,因?yàn)槲覀儷@得表單中的值都是通過預(yù)先設(shè)置好了的get方法來得到的,那么如果有些參數(shù)我們必須通過request.getParametre或者session.getAttribute來得到,那么應(yīng)該怎么做呢?按照Max的教程上的說法,可以分為兩種:IoC方式和非IoC方式,如何理解這兩種方式的區(qū)別呢?IoC是Spring里面的特征之一,字面意思是反轉(zhuǎn)控制,說白了就是依賴注入,比方說類A依賴類B,那么就主動的給A注入一個類B的對象,下面看一下這兩種方法的具體實(shí)現(xiàn)。
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進(jìn)行讀寫了,如果我們想得到原始的HttpSession可以首先得到HttpServletRequest對象,然后通過request.getSession()來取得原始的HttpSession對象。一般情況下SessionMap已經(jīng)可以完成所有的工作,我們不必再去碰底層的session了。
2.IoC方式
這種方式相對來說變化就比較少了,具體流程如下所示。
獲得request對象:
第一步:讓action實(shí)現(xiàn)ServletRequestAware接口
第二步:在action中聲明一個HttpServletRequest類型的實(shí)例變量
第三步:在action中實(shí)現(xiàn)ServletRequestAware接口的setServletRequest方法,實(shí)現(xiàn)方式很簡單,如下所示。
private HttpServletRequest request;
public void setServletRequest(HttpServletRequest request) {
this.request = request;
}
獲得Session對象(注意,此時的session是SessionMap類型):
第一步:讓action實(shí)現(xiàn)SessionAware接口
第二步:在action中聲明一個HttpServletRequest類型的實(shí)例變量
第三步:在action中實(shí)現(xiàn)SessionAware接口的setSession方法,實(shí)現(xiàn)方式很簡單,如下所示。
private Map session;
publicvoid setSession(Map session) {
this. session = session;
}
以下是另一篇關(guān)于得到Request和Session的文章: