public class MyInterceptor extends com.opensymphony.xwork2.interceptor.Interceptor{ @Override public String intercept(ActionInvocation invocation) throws Exception { //<action name="xxx" class="yyy" method="zzz"> String namespace_action = invocation.getProxy().getNamespace();//命名空间 String actionName_action = invocation.getProxy().getActionName();//action名字xxx String method_action = invocation.getProxy().getMethod();//method名字zzz ActionContext context = invocation.getInvocationContext(); Map<String, Object> session = context.getSession(); HttpServletRequest request = (HttpServletRequest) invocation .getInvocationContext().get(StrutsStatics.HTTP_REQUEST); HttpServletResponse response = (HttpServletResponse) invocation .getInvocationContext().get(StrutsStatics.HTTP_RESPONSE); } }
下面是一个处理同一账号只能在一个地方登陆的拦截器简单实现:
package com.tch.test.ssh.interceptor; import java.util.Date; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpSession; import org.apache.struts2.StrutsStatics; import org.springframework.stereotype.Component; import com.opensymphony.xwork2.ActionContext; import com.opensymphony.xwork2.ActionInvocation; import com.opensymphony.xwork2.interceptor.Interceptor; import com.tch.test.ssh.entity.User; import com.tch.test.ssh.info.LoginInfo; import com.tch.test.ssh.info.UserInfo; @Component("checkLogin") public class CheckLoginInterceptor implements Interceptor { private static final long serialVersionUID = 1L; @Override public String intercept(ActionInvocation invocation) throws Exception { System.out.println("interceptor............................"); HttpServletRequest request = (HttpServletRequest) invocation.getInvocationContext().get(StrutsStatics.HTTP_REQUEST); String url = request.getRequestURI(); if(url.contains("/ssh/login.action")){ //登陆 return invocation.invoke(); } //已经登陆 HttpSession session = request.getSession(); Date current_login_time = (Date) session.getAttribute("login_time");//一个账号登陆之后会在session中保存此次登陆的时间 User user = (User) session.getAttribute("login_user"); if(user == null || user.getId() == null || current_login_time == null){ //session中没有相关信息,则重新登录 return "login"; } LoginInfo info = (LoginInfo)UserInfo.LOGIN_USERS.get(user.getId());//账号登陆之后,会在服务器端保存该账号的登录时间,当有另外一个登陆的时候,会更新该时间,从而保证是最近的登陆时间 if(info != null && info.getLoginTime() != null){ Date latest_login_time = info.getLoginTime(); if(latest_login_time.getTime() > current_login_time.getTime()){//比较session中的登录时间和服务器保存的登录时间,确定该登陆是否是最新的登陆 ActionContext.getContext().put("errorMessage", "账号在别处登录,当前用户被强制退出 !"); session.invalidate(); System.out.println("*****************删除session*************"); return "error"; } } return invocation.invoke(); } @Override public void destroy() { } @Override public void init() { } }
然后再struts.xml中配置该拦截器:
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN" "http://struts.apache.org/dtds/struts-2.3.dtd"> <struts> <constant name="struts.enable.DynamicMethodInvocation" value="true" /> <constant name="struts.devMode" value="true" /> <!-- 定义一个自己的package,在里面定义拦截器栈,后面的package继承该package即可使用里面的拦截器 --> <package name="mypackage" extends="struts-default"> <interceptors> <interceptor name="checkLogin" class="checkLogin"></interceptor> <interceptor-stack name="myStack"> <interceptor-ref name="checkLogin"/> <interceptor-ref name="defaultStack"/> </interceptor-stack> </interceptors> <!-- 设置默认的拦截器栈为自定义的拦截器栈,这样就可以对所有的请求拦截处理了 --> <default-interceptor-ref name="myStack"/> </package> <package name="default" namespace="/" extends="mypackage"> <default-action-ref name="index" /> <global-results> <result name="error">/user/pages/loginError.jsp</result> <result name="login">/index.jsp</result> </global-results> <global-exception-mappings> <exception-mapping exception="java.lang.Exception" result="error" /> </global-exception-mappings> <action name="show" class="userAction" method="select"> <result>/WEB-INF/pages/User.jsp</result> </action> <action name="goEdit" class="userAction" method="goEdit"> <result>/WEB-INF/pages/editUser.jsp</result> </action> <action name="login" class="userAction" method="login"> <result>user/pages/all.jsp</result> <result name="error">/user/pages/loginError.jsp</result> </action> <!-- 使用通配符 --> <action name="*User" class="userAction" method="{1}User"> <result type="redirectAction"> <param name="actionName">show</param> <param name="namespace">/</param> </result> </action> </package> </struts>
相关推荐
Struts2 Interceptor详解 Struts2作为一款流行的Java Web框架,其强大的功能之一就是拦截器(Interceptor)。拦截器在MVC模式中扮演着重要角色,它可以对请求进行预处理和后处理,提供了灵活的扩展机制,使得业务...
在Struts2中,自定义拦截器需要继承`com.opensymphony.xwork2.interceptor.Interceptor`接口,并实现其三个方法:`void destroy()`、`void init()` 和 `String doIntercept(ActionInvocation invocation)`。...
2. **拦截器栈**:多个拦截器的集合称为拦截器栈,Struts2默认提供了几个内置的拦截器栈,如`defaultStack`、`jsonStack`等,也可以自定义拦截器栈。 3. **拦截器配置**:拦截器可以通过Struts2的配置文件`struts....
在Struts2框架中,**Interceptor(拦截器)**是一个关键组件,它允许开发者在特定的动作(Action)执行前后添加自定义的处理逻辑,极大地增强了应用程序的灵活性。 #### 二、Interceptor 概念与作用 Interceptor ...
在深入探讨自定义拦截器之前,我们先理解一下Struts2拦截器的基本概念。 拦截器(Interceptor)是基于Java的动态代理机制实现的,它可以拦截用户的请求,对请求进行预处理,并且在Action执行后进行后处理。通过在...
在Struts2的配置文件(通常是`struts.xml`)中,添加标签库的配置,让框架知道如何找到并使用这些自定义标签。 ```xml <struts> <!-- 其他配置 --> <constant name="struts.custom.i18n.resources" value=...
配置Struts2框架以使用自定义拦截器是关键步骤。在`struts2.xml`配置文件中,你需要在合适的`<package>`标签下定义拦截器。例如: ```xml <package name="customPackage" namespace="/" extends="struts-default"> ...
### Struts2 自定义验证程序的实现方法详解 #### 一、Struts2 内建验证程序实现的分析 在探讨如何实现自定义验证程序之前,我们先来了解一下 Struts2 的内置验证机制。Struts2 提供了丰富的内置验证器(Validator...
Struts2自定义拦截器的配置是Struts2框架中一个非常重要的功能,它允许开发者在Action执行前后插入自定义的逻辑,以实现如权限验证、日志记录、性能监控等多种需求。以下是对标题和描述中涉及的知识点的详细说明: ...
import org.apache.struts2.interceptor.validation.SkipValidation; import com.example.CustomType; import static com.opensymphony.xwork2.Action.SUCCESS; @Action(value = "customAction", results = { @...
在默认情况下,Struts2能够自动处理基本类型和简单类型的转换,但当我们需要对复杂的数据类型或者自定义类型的转换时,就需要自定义类型转换器。本文将深入探讨如何在Struts2中实现自定义类型转换器,以便将用户输入...
这篇博客文章可能是关于如何在Struts2中创建和使用自定义拦截器的教程。 在Struts2中,拦截器是基于责任链模式实现的,它们按照指定的顺序执行,对请求进行处理。拦截器可以用来进行权限检查、日志记录、事务管理等...
通常,Struts2框架内置了一些基本类型的转换器,但有时我们需要对特定的数据类型进行自定义转换,这时就需要编写自定义的转换类。下面将详细讲解如何在Struts2中实现自定义转换类。 首先,了解Struts2的转换机制。...
本示例将聚焦于如何在Struts2中实现一个自定义拦截器。 首先,我们需要了解拦截器在Struts2中的作用。拦截器是AOP(面向切面编程)的一个核心概念,它允许开发者在动作执行前后插入额外的逻辑,如日志记录、权限...
本实例练习旨在帮助你深入理解Struts2的工作原理,特别是自定义类型转换和拦截器的使用。 首先,让我们详细探讨Struts2的MVC架构。在MVC模式中,Model代表业务逻辑,View负责展示数据,而Controller则是两者之间的...
5. **自定义Interceptor**:开发自定义Interceptor需要继承`org.apache.struts2.interceptor.Interceptor`接口或实现`com.opensymphony.xwork2.interceptor.Interceptor`接口,并重写`intercept()`方法。在`...
在Struts2中,拦截器(Interceptor)扮演着关键角色,它们允许开发者在Action执行前后插入自定义逻辑,比如日志记录、权限验证、数据校验等。本文将深入探讨Struts2的内建自定义拦截器及其配置。 首先,让我们理解...