在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對象:
A.HttpServletRequest request = ServletActionContext.getRequest ();
B.ActionContext ct= ActionContext.getContext()
HttpServletRequest request=
(HttpServletRequest)ct.get(ServletActionContext.HTTP_REQUEST);
獲得session對象:
在Struts2中底層的session都被封裝成了Map類型,我們稱之為SessionMap,而平常我們所說的session則是指HttpSession對象,具體的獲得方法如下所示。
A.Map session=ActionContext.getSession();
B.Map session=(Map)ActionContext.getContext().get(ActionContext.SESSION);
得到這個SessionMap之后我們就可以對session進行讀寫了,如果我們想得到原始的HttpSession可以首先得到HttpServletRequest對象,然后通過request.getSession()來取得原始的HttpSession對象。一般情況下SessionMap已經可以完成所有的工作,我們不必再去碰底層的session了。
2.IoC方式
這種方式相對來說變化就比較少了,具體流程如下所示。
獲得request對象:
第一步:讓action實現ServletRequestAware接口
第二步:在action中聲明一個HttpServletRequest類型的實例變量
第三步:在action中實現ServletRequestAware接口的setServletRequest方法,實現方式很簡單,如下所示。
private HttpServletRequest request;
publicvoid 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;
}
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1721226