struts2对拦截器使用带实例

拦截器是struts2的核心。拦截器可以拦截请求,控制视图的走向。那么怎么来实现自定义的拦截器呢?

这里我们做一个例子。

 

首先假现在做了两个jsp页面一个是登陆的信息的(用session来模拟),一个是没有登陆的信息的。

 

 

有登陆信息的叫login.Jsp

  <%request.getSession().setAttribute("sess","fish" ) ;%>

   用户已登录

 

 

没有登陆信息的叫做

Quit.JSP

   <%request.getSession().removeAttribute("sess"); %>

            用户已退出!

 

 

然后一个全局视图跳转的jsp页面,message.JSP

${message}

 

现在定义一个拦截器:MyIntercerptor.Java

packagecom.fish;

 

importcom.opensymphony.xwork2.ActionContext;

importcom.opensymphony.xwork2.ActionInvocation;

importcom.opensymphony.xwork2.interceptor.AbstractInterceptor;

 

public class MyInterceptor extends AbstractInterceptor {//继承拦截器的抽象类

 

 

    @Override

    public String intercept(ActionInvocation invokcation) throws Exception {

    Object session= ActionContext.getContext().getSession().get("sess");//首先或得这个session对象

        if(session!=null)//如果有sess说明用户登陆成功了

        return invokcation.invoke();//那么调用这个方法就可以中断这个intercept()方法。那么后面的代码就不会执行了。如果没有sess对象就说明了你没有登陆。那么就执行了下面的方法。这句话就是拦截器的核心。

        ActionContext.getContext().put("message", "你没有权限");//设置一个request对象

        return "success";//返回这个试图。

    }

 

}

 

接着我们看看struts2.xml

<package name="fish"namespace="/test" extends="struts-default">

 

<interceptors>

<interceptor name="my"class="com.fish.MyInterceptor"></interceptor>//首先注册这个拦截器。如果要想拦截器发挥作用只要把拦截器放到action下面,<interceptor-ref name="XXX"/>调用就行了,但是在action只要调用拦截器就不会执行原来的struts自身的拦截器,说以我们定义一个拦截器栈,将系统的拦截器和自定义的拦截放在里面就行了,调用的时候主要吧拦截器栈写名字<interceptor-ref name="xx">

<interceptor-stack name="aa">//注册一个拦截器栈,

<interceptor-ref name="defaultStack"></interceptor-ref>//一般顺序就是struts自身的拦截器

<interceptor-ref name="my"></interceptor-ref>//然后自定义的拦截器

</interceptor-stack>

</interceptors>

<global-results><result>/message.jsp</result></global-results>

<action name="redfish"  class="com.fish.Test"method="execute">

<result name="success">/message.jsp</result>

<interceptor-ref name="aa"></interceptor-ref>//这里调用的拦截器栈

</action>

</package>

 

测试结果:

启动服务器。直接

http://127.0.0.1:8080/struts2test7/test/redfish

这样的话会显示:“权限不够”,显然是因为拦截器已经起作用了。因为开始session没有赋值

如果: http://127.0.0.1:8080/struts2test7/login.jsp

然后:http://127.0.0.1:8080/struts2test7/test/redfish

这样会显示:“你好”,因为这样session就有了。有了session就相当于有权限,拦截器就不会拦截了,可以自由访问action的试图。

 

你可能感兴趣的:(struts2)