Struts2之拦截器

使用拦截器检测用户是否登录

步骤一、实现拦截器类(有三种方法

1、实现Interceptor 接口 , 需要实现3个方法
a . void init( ) 初始化拦截器所需要的资源
b. void destory( ) 释放在init()中分配的资源
c. Stirng intercept( ActionInvocation ai) 实现拦截器功能
其中,init和destroy方法会在程序开始和结束时各执行一遍,不管使用了
该拦截器与否,只要在struts.xml中声明了该Struts2拦截器就会被执行。
intercept方法就是拦截的主体了,每次拦截器生效时都会执行其中的逻辑
2、继承AbstractInterceptor抽象类, 这是最常用的方式

   该抽象类中提供了init()方法和destory()方法的空实现
   继承该抽象类时,子类只需要实现intercept()方法即可

3、继承MethodFilterInterceptor 类,只拦截部分Action 的方法时使用

**无论使用上述哪种方式,需要指出的是一个很重要的方法invocation.invoke(),这是ActionInvocation中的方法, 其作用是:

调用下一个拦截器或Action,并且将拦截器中的代码分成2个部分,在invocation.invoke()之前的代码,将会在Action之前被依次执行,而在invocation.invoke()之后的代码,将会在Action之后被执行。
由此,我们就可以通过invocation.invoke()作为Action代码真正的拦截点,从而实现AOP**

步骤二、三、在package中定义拦截器,在action中引用拦截器

<!-- 配置自定义拦截器 -->
    <interceptors>
        <interceptor name="checkuserlogin" class="com.userInterceptor.CheckUserLogin"></interceptor>
        <!-- 定义拦截器栈 --> 
        <interceptor-stack name="ydStack">
             <!-- 引用具体拦截器 -->
             <interceptor-ref name="defaultStack"></interceptor-ref>
             <interceptor-ref name="checkuserlogin">
                 <!-- 用来设置拦截器的白名单,凡是加入白名单的方法都会进行拦截 -->
                 <!--  <param name="includeMethods">方法名1,方法名2</param>  -->
                 <!-- 用来设置拦截器的黑名单,凡是加入黑名单的方法都不会进行拦截 -->
                 <param name="excludeMethods">login</param>
             </interceptor-ref>
        </interceptor-stack>
    </interceptors>

    <!-- 启动自定义拦截器栈 -->
    <default-interceptor-ref name="ydStack"></default-interceptor-ref>

自定义拦截器的关键代码

public class CheckUserLogin extends MethodFilterInterceptor{
    @Override
    protected String doIntercept(ActionInvocation ai) throws Exception {
        // TODO Auto-generated method stub
        HttpSession session = ServletActionContext.getRequest().getSession();
        Object obj=session.getAttribute("username");
        String result;
        if(obj==null){
            result="loginfail";
        }else{
            //调用下一个拦截器或Action的方法
            result=ai.invoke();
        }
        return result;
    }
}

总结:同过配置该拦截器,可以防止用户非法访问,当用户没有登录却访问其他URL时,系统会自动将页面跳转到登录页面。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值