SSH中action访问session的方法!

3 篇文章 0 订阅
1 篇文章 0 订阅

第一种:通过实现SessionAware接口来获取action

@SuppressWarnings("serial")
public class SurveyAction extends BaseAction<Surveys> implements SessionAware {
 @Resource
 private SurveysService surveyService;
 //接收session
 private Map<String, Object> sessionMap;
 //接收返回集合
 private List<Surveys> mySurveys;
 public List<Surveys> getMySurveys() {
  return mySurveys;
 }
 public void setMySurveys(List<Surveys> mySurveys) {
  this.mySurveys = mySurveys;
 }
 public void setSession(Map<String, Object> arg0) {
  this.sessionMap=arg0;
 }
 public String mySurveys(){
  Users user=(Users)sessionMap.get("users");
  this.mySurveys=surveyService.findMySurveys(user);
  return "toMySurveys";
 }
}

---------------------------------------------------------------------------------------------------------------

第二种(转):

 添加属性:ActionContext.getContext().getSession().put();

获得request对象:

  1. HttpServletRequest request = ServletActionContext.getRequest ();
  2. ActionContext ctActionContext.getContext()
  3.    HttpServletRequest request=
  4. (HttpServletRequest)ct.get(ServletActionContext.HTTP_REQUEST);

获得session对象:
在Struts2中底层的session都被封装成了Map类型,我们称之为SessionMap,而平常我们所说的session则是指HttpSession对象,具体的获得方法如下所示。

  1. Map session=ActionContext.getSession();
  2. Map session=(Map)ActionContext.getContext().getActionContext.SESSION)

得到这个SessionMap之后我们就可以对session进行读写了,如果我们想得到原始的HttpSession可以首先得到HttpServletRequest对象,然后通过request.getSession()来取得原始的HttpSession对象。一般情况下SessionMap已经可以完成所有的工作,我们不必再去碰底层的session了。

Struts2 的Action中若希望访问Session对象,可采用两种方式:

1、从ActionContext中获取;

2、实现SessionAware接口。

 

1、从ActionContext中获取:

  1. import java.util.Map;  
  2. import com.opensymphony.xwork2.ActionContext;  
  3. import com.opensymphony.xwork2.ActionSupport;  
  4. public class SessionTestAction extends ActionSupport {  
  5.     public String execute() {  
  6.      ActionContext actionContext = ActionContext.getContext();  
  7.        Map session = actionContext.getSession();  
  8.        session.put("USER_NAME""Test User");  
  9.        return SUCCESS;  
  10.     }  
  11. }  
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;
    }
}


2、实现SessionAware接口:

  1. import java.util.Map;  
  2. import org.apache.struts2.interceptor.SessionAware;  
  3. import com.opensymphony.xwork2.ActionSupport;  
  4. public class SessionTest1Action extends ActionSupport implements SessionAware {  
  5.     private Map session;  
  6.     public void setSession(Map session) {  
  7.        this.session = session;  
  8.     }  
  9.     public String execute() {  
  10.        this.session.put("USER_NAME""Test User 1");  
  11.        return SUCCESS;  
  12.     }  
  13. }  
import java.util.Map;
import org.apache.struts2.interceptor.SessionAware;
import com.opensymphony.xwork2.ActionSupport;
public class SessionTest1Action extends ActionSupport implements SessionAware {
    private Map session;
    public void setSession(Map session) {
       this.session = session;
    }
    public String execute() {
       this.session.put("USER_NAME", "Test User 1");
       return SUCCESS;
    }
}

进一步阅读Struts2.1.8.1源码,SessionAware接口的实现方式如下:

  1. <interceptors>  
  2.   ...  
  3.   <interceptor name="servletConfig" class="org.apache.struts2.interceptor.ServletConfigInterceptor"/>  
  4.   ...  
  5. </interceptors>  
  6. <interceptor-stack name="defaultStack">  
  7.   ...  
  8.   <interceptor-ref name="servletConfig"/>  
  9.   ...  
  10. </interceptor-stack>  
<interceptors>
  ...
  <interceptor name="servletConfig" class="org.apache.struts2.interceptor.ServletConfigInterceptor"/>
  ...
</interceptors>
<interceptor-stack name="defaultStack">
  ...
  <interceptor-ref name="servletConfig"/>
  ...
</interceptor-stack>


打开ServletConfigInterceptor.java源码:

  1. public String intercept(ActionInvocation invocation) throws Exception {  
  2.     final Object action = invocation.getAction();  
  3.     final ActionContext context = invocation.getInvocationContext();  
  4.       
  5.     ...  
  6.     if (action instanceof SessionAware) {  
  7.         ((SessionAware) action).setSession(context.getSession());  
  8.     }  
  9.     ...  
  10.     return invocation.invoke();  
  11. }  
public String intercept(ActionInvocation invocation) throws Exception {
    final Object action = invocation.getAction();
    final ActionContext context = invocation.getInvocationContext();
    
    ...
    if (action instanceof SessionAware) {
        ((SessionAware) action).setSession(context.getSession());
    }
    ...
    return invocation.invoke();
}

即在拦截器处理过程中发现目标Action实现了SessionAware接口,便会调用Action中已经实现的setSession(...)方法,将ActionContext中包装的Session注入目标Action中。目标Action也就可以进一步对Session进行操作了。

来自:http://blog.csdn.net/puffcn/article/details/5607557

 

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值