登录拦截器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,苹果还是苹果,暴雪还是暴雪,而这些牛人离开了公司,自己什么都不是。
 
                    
                     
                    
                 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号