java 拦截器

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java 拦截器相关的知识,希望对你有一定的参考价值。

@Override
public String intercept(ActionInvocation invocation) throws Exception
Object obj = invocation.getAction();
String method = invocation.getProxy().getMethod();
StringBuffer note =new StringBuffer(); //note
StringBuffer operation = new StringBuffer(); //用户操作
Map<String,Object> params = invocation.getInvocationContext().getParameters();
if(obj instanceof LoginAction) // 登录有关的action
if("auth".equals(method))

operation.append("用户登录");
HttpServletRequest request = ServletActionContext.getRequest();
this.getAdminLogParams(getParamter(params,"admin.username"), operation, "用户登录IP:"+request.getRemoteAddr());
else if("logout".equals(method))
operation.append("用户注销");
Admin user = (Admin) invocation.getInvocationContext().getSession().get(Constant.LOGIN_SESSION_KEY);
this.getAdminLogParams(user.getUsername(), operation, "用户退出");

return invocation.invoke();
else
//........................


我在登录Action 有个标识 但是这个拦截器是在进入action方法之前就执行 所有标识一直没起到作用 怎么让拦截器在进入action 方法之后 执行 最好是让拦截器 登录成功 那一块 单独的在 进入action方法之后运行
如果不行就让整个拦截器都在方法之后运行
配置文件如下:
<interceptors>
<interceptor name="checkLoginInterceptor" class="com.saleAdmin.web.interceptors.CheckLoginInterceptor"/>
<interceptor-stack name="checkLoginStack">
<interceptor-ref name="checkLoginInterceptor"/>
<interceptor-ref name="defaultStack"/>
</interceptor-stack>
</interceptors>

好像是不行吧!拦截器是拦截客户端请求和服务端响应的,Action是处理客户端请求并生成响应的,拦截器是工作在两者之间的,对客户端的请求拦截,对服务端的响应拦截。 参考技术A 你可以使用spring的aop组件 参考技术B 什么意思追问

就是让拦截器在进入action之后再运行拦截器

Struts2拦截器 关于解决登录的问题_java - JAVA

文章来源:嗨学网 敏而好学论坛www.piaodoo.com 欢迎大家相互学习

技术图片

拦截器的工作原理如图 拦截器是由每一个action请求(request)都包装在一系列的拦截器的内部,通过redirectAction再一次发送请求。

拦截器可以在Action执行直线做相似的操作也可以在Action执行直后做回收操作。

我们可以让每一个Action既可以将操作转交给下面的拦截器,Action也可以直接退出操作返回客户既定的画面。

接下来我们该如何定义一个拦截器:

自定义一个拦截器如下:

1、实现Interceptor接口或者继承AbstractInterceptor抽象类。

2、创建一个Struts.xml文件进行定义拦截器。

3、在需要使用的Action中引用上述定义的拦截器,为了方便也可将拦截器定义为默认的拦截器(<default-interceptor-ref name="myStack"/>),

这样在不加特殊声明的情况下所有的Action都被这个拦截器拦截<param name="excludeMethods">loginView,login</param>。

①Interceptor接口声明三个方法:

public class LoginInterceptor implements Interceptor {

 private Map<String,Object> session = null;
 public void destroy() { }
 public void init() { }
 public String intercept(ActionInvocation actionInvocation) throws Exception {
 8     Object myAction = actionInvocation.getAction();
  if(myAction instanceof UserAction){
   System.out.println("你访问的Action是UserAction,不要校验Session,否则死循环");
   //放行
   return actionInvocation.invoke();
  }else{
   System.out.println("你访问的Action是:"+myAction);
  }

  session = ActionContext.getContext().getSession();
  Object user = session.get("user");
  if (user!=null){
   return actionInvocation.invoke();
  }else{
   return "login";
  }

}

注:该方法可以不加:<param name="excludeMethods">loginView,login</param>

②让它继承 MethodFilterInterceptor:

public class LoginInterceptor extends MethodFilterInterceptor {
 private Map<String,Object> session = null;
 protected String doIntercept(ActionInvocation actionInvocation) throws Exception {
  /*
  Object myAction = actionInvocation.getAction();
  if(myAction instanceof UserAction){
   System.out.println("你访问的Action是UserAction,不要校验Session,否则死循环");
   //放行
   return actionInvocation.invoke();
  }else{
   System.out.println("你访问的Action是:"+myAction);
  }
  */
  session = ActionContext.getContext().getSession();
  Object user = session.get("user");
  if (user!=null){
   return actionInvocation.invoke();
  }else{
   return "login";
  }
 }
}

③UserAction继承ActionSupport 实现 ModelDriven<User>和SessionAware:

public class UserAction extends ActionSupport implements ModelDriven<User>,SessionAware{

 private Map<String,Object> session = null;
 private User user = null;
   //驱动模型
 public User getModel() {
  this.user = new User();
  return this.user;
 }

 public void setSession(Map<String, Object> map) {
  this.session = map;
 }

 public String loginView(){
  return "loginViewSuccess";
 }

 public String login(){
  if ("admin".equals(user.getUserName())&&"123456".equals(user.getUserPassword())){
   session.put("user",user);
   return this.SUCCESS;
  }else{
   return this.ERROR;
  }

 }
}

Struts.xml文件中:

<struts>
 <package name="myPackage" extends="struts-default">

  <interceptors>

   <interceptor name="loginInterceptor" class="com.nf.action.LoginInterceptor"></interceptor>
   <interceptor-stack name="myStack">
    <interceptor-ref name="loginInterceptor">
     <!--excludeMethods需要生效的话,自定义的拦截器,不能使用实现Interceptor接口,而是extends MethodFilterInterceptor-->
     <param name="excludeMethods">loginView,login</param><!--不用此行时 我们可以配合①使用拦截器-->
    </interceptor-ref>
    <interceptor-ref name="defaultStack"></interceptor-ref>
   </interceptor-stack>
  </interceptors>
  <!--配置一个默认拦截器,也就是所有的Action都必须使用-->
  <default-interceptor-ref name="myStack"/>
  <global-results>
   <result name="login" type="redirectAction">userAction_loginView</result>
  </global-results>
  <!--不写method,默认就是execute-->
  <action name="indexAction" class="com.nf.action.IndexAction" method="execute">
   <result name="success">/WEB-INF/jsp/index.jsp</result>
   <!--
   <interceptor-ref name="myStack"></interceptor-ref>
   -->
   <!--注释这里也可以放该代码 只不过每一个action都要放比较麻烦 
   <interceptor-ref name="loginInterceptor"></interceptor-ref>
   <interceptor-ref name="defaultStack"></interceptor-ref>
   -->
  </action>

  <action name="otherFunctionAction" class="com.nf.action.OtherFunctionAction">
   <!--不写name,默认就是success-->
   <result>/WEB-INF/jsp/otherFunction.jsp</result>
  </action>
  
  <action name="userAction_*" class="com.nf.action.UserAction" method="{1}">
   <result name="loginViewSuccess">/WEB-INF/jsp/loginView.jsp</result>
   <result name="error">/WEB-INF/jsp/error.jsp</result>
   <result name="success" type="redirectAction">indexAction</result>
   <allowed-methods>login,loginView</allowed-methods>
  </action>
 </package>
</struts>

其中,<param name="excludeMethods">loginView,login</param> 配置的过滤方法,意思是拦截器对其中的方法不起作用。在我这里,loginView是跳转到登录页面的方法。

login 是验证用户名和密码的方法,在其中会将通过验证的用户名放入session中。

总结:

1.在struts2 中,所有的拦截器都会继承 Interceptor 这个接口。

2.如果我们没有添加拦截器,struts2 会为我们添加默认拦截器。当然我们要是指定了拦截器,我们自己的拦截器就会取代默认的拦截器,

那么我们就不能享受默认拦截器提供的一些功能。所以,一般我会把默认拦截器也加上。

例如,在以上配置项中,action 里面再加上<interceptor-ref name="defaultStack"></interceptor-ref>

以上这篇Struts2拦截器 关于解决登录的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持敏而好学论坛/嗨学网。

原文地址是:http://www.piaodoo.com/thread-13252-1-1.html 丝袜控www.txdah.com 131www.buzc.org学习之外可赏心悦目有助更好地学习!

以上是关于java 拦截器的主要内容,如果未能解决你的问题,请参考以下文章

解释一下Java反射,aop,拦截器,过滤器。

java web 过滤器跟拦截器的区别和使用

java web拦截器inteceptor

java 拦截器

Struts2拦截器 关于解决登录的问题_java - JAVA

java struts学习-拦截器