登录拦截器actionInvocation.invoke()是什么意思,配置自己的验证拦截器

发一下牢骚和主题无关:

    关于Struts2的自定义的验证截器

    

package ch06.struts2.Interceptor;

import java.util.Map;

import com.opensymphony.xwork2.Action;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.Interceptor;


public class AuthenticationInterceptor implements Interceptor  {

  private static final long serialVersionUID = 1L;
 
  public static final String USER_SESSION_KEY = "UserSessionKey";
  
  public void destroy() {}

  public void init() {}


     public String intercept(ActionInvocation actionInvocation) throws Exception {
   //取得Session
         Map session = actionInvocation.getInvocationContext().getSession();
   //从Session里取得登录时保存进session的User类
         String user = (String) session.get(USER_SESSION_KEY);
         //判断用户名是不是为空  
         boolean isAuthenticated = (null!=user);
         if (!isAuthenticated) {//如果未通过登录验证

           //上面的那个return怎么能返回登录页面
             return Action.LOGIN;   //返回登录页面  
      
         }else{       
    // 上面的这个actionInvocation.invoke()是什么意思
         return actionInvocation.invoke();//返回验证通过         
         }
     }
}

    当我们实现了intercept(ActionInvocation invocation)方法后,可以取得ActionInvocation 参数,这个参数可以取得被拦截的

    每日一道理
如果你们是蓝天,我愿做衬托的白云;如果你们是鲜花,我愿做陪伴的小草;如果你们是大树,我愿做点缀的绿叶……我真诚地希望我能成为你生活中一个欢乐的音符,为你的每一分钟带去祝福。

    Action的实例,就等于取得了所有的控制权,就能够获的参数。

    

    struts.xml配置自定义的拦截器

    

<!-- 自定义验证拦截器 -->
     <interceptors>
   <interceptor name="Authentication"  class="ch06.struts2.Interceptor.AuthenticationInterceptor" />     
  </interceptors> 

<action name="Welcome">
            <interceptor-ref name ="Authentication"/>
            <result name="success">welcome.jsp</result>
</action>

    

最后actionInvocation.invoke() 就是通知struts2接着干上面的事情

    

比如 调用下一个拦截器 或 执行下一个Action

    

就等于退出了你自己编写的这个interceptor了,继续执行本来的action

文章结束给大家分享下程序员的一些笑话语录: 很多所谓的牛人也不过如此,离开了你,微软还是微软,Google还是Google,苹果还是苹果,暴雪还是暴雪,而这些牛人离开了公司,自己什么都不是。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值