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的试图。

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值