struts2之implements SessionAware, ServletRequestAware, ServletResponseAware原理分析

我们在开发项目一般会新建一个action父类,然后让所有的子类来继承它。下面的代码展示了我们在新建父类时实现了SessionAware, ServletRequestAware, ServletResponseAware三个接口,实现这三个接口的目的是自动创建session,HttpServletRequest,HttpServletResponse来为我们服务。下面我们就从源码的角度来分析一下为什么实现了这三个接口struts框架就会帮我们自动创建session,HttpServletRequest,HttpServletResponse的实现。

public class MyActionSupport extends ActionSupport
        implements SessionAware, ServletRequestAware, ServletResponseAware {

    protected Map<String, Object> session;
    protected HttpServletRequest request;
    protected HttpServletResponse response;

    @Override
    public void setServletRequest(HttpServletRequest request) {
        this.request = request;
    }

    @Override
    public void setServletResponse(HttpServletResponse response) {
        this.response = response;
    }

    @Override
    public void setSession(Map<String, Object> session) {
        this.session = session;
    }
}

1.在struts的配置文件struts.xml中我们定义了自己的拦截器,同时把默认的拦截器包含到自定义的拦截器栈,同时设置系统的拦截器栈。我们之所以可以引用默认拦截器到我们自己的拦截器中,是因为在我们自己的配置文件继承了struts自带的配置文件struts-default.xml

<struts>
    <package name="myDefault" extends="struts-default">

        <interceptors>
            <interceptor name="checkLogin"
                class="com.deity.finance.interceptors.CheckLogin" />
            <interceptor-stack name="checkLoginStack">
                <interceptor-ref name="checkLogin" />
                <interceptor-ref name="defaultStack" />
            </interceptor-stack>
        </interceptors>

        <default-interceptor-ref name="checkLoginStack"/>
        ......

2.下面是struts-default.xml中关于默认拦截器servletConfig的配置情况,我们之所以要列出该拦截器的配置情况,是因为拦截器就是自动创建session的关键。下面让我们继续查看该拦截器的源码

<interceptors>
            ......
            <interceptor name="servletConfig" class="org.apache.struts2.interceptor.ServletConfigInterceptor"/>
            ......
</interceptors>


<interceptor-stack name="defaultStack">
                <interceptor-ref name="exception"/>
                <interceptor-ref name="alias"/>
                <interceptor-ref name="servletConfig"/>
                ......
</interceptor-stack>

3.从servletConfig拦截器的代码中我们可以看到,首先拦截器会判断action是否实现了SessionAware, ServletRequestAware, ServletResponseAware接口,如果实现的话就从context获取相应的session,request,response通过set方法赋值给action属性,这样我们就通过实现接口可以获取到相应的属性来为我们服务了。

public class ServletConfigInterceptor extends AbstractInterceptor implements StrutsStatics {

    private static final long serialVersionUID = 605261777858676638L;

    public String intercept(ActionInvocation invocation) throws Exception {
        final Object action = invocation.getAction();
        final ActionContext context = invocation.getInvocationContext();

        if (action instanceof ServletRequestAware) {
            HttpServletRequest request = (HttpServletRequest) context.get(HTTP_REQUEST);
            ((ServletRequestAware) action).setServletRequest(request);
        }

        if (action instanceof ServletResponseAware) {
            HttpServletResponse response = (HttpServletResponse) context.get(HTTP_RESPONSE);
            ((ServletResponseAware) action).setServletResponse(response);
        }

        if (action instanceof SessionAware) {
            ((SessionAware) action).setSession(context.getSession());
        }
        ......
        return invocation.invoke();
    }
}
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值