(1)
aop 是spring 切面编程,
@aspect
在spring-servlet.xml 中配置aop
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:p="http://www.springframework.org/schema/p" xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="
http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/aophttp://www.springframework.org/schema/aop/spring-aop-2.5.xsd">
<aop:aspectj-autoproxy proxy-target-class="true" />
<bean class="com.aop.XXXX" />
2.1 定义Pointcut
1. package com.sarkuya.aop.aspect;
2. import org.aspectj.lang.annotation.Aspect;
3. import org.aspectj.lang.annotation.Pointcut;
4. @Aspect
5. public class SampleAspect {
6. @Pointcut("execution(* com.sarkuya.service..*.*(..))")
7. public void inServiceLayer() {
8. }
9. }
Pointcut是植入Advice的触发条件。每个Pointcut的定义包括2部分,一是表达式,如第6行;二是方法签名,如第7行。方法签名必须是 public及void型。可以将Pointcut中的方法看作是一个被Advice引用的助记符,因为表达式不直观,因此我们可以通过方法签名的方式为 此表达式命名。因此Pointcut中的方法只需要方法签名,而不需要在方法体内编写实际代码。(转)
领一种环绕就是@around
public Object arount(proceedingJoinPoint p){
String name=p.getSignature.indexOf().getName();
//登陆请求时不拦截
if(name.indexOf('login')!=-1)
//获取session
return p.proceed
}
(2)(转)
Interceptor 是spring mvc框架的
- /**
- * preHandle方法是进行处理器拦截用的,顾名思义,该方法将在Controller处理之前进行调用,SpringMVC中的Interceptor拦截器是链式的,可以同时存在
- * 多个Interceptor,然后SpringMVC会根据声明的前后顺序一个接一个的执行,而且所有的Interceptor中的preHandle方法都会在
- * Controller方法调用之前调用。SpringMVC的这种Interceptor链式结构也是可以进行中断的,这种中断方式是令preHandle的返
- * 回值为false,当preHandle的返回值为false的时候整个请求就结束了。
- */
- @Override
- public boolean preHandle(HttpServletRequest request,
- HttpServletResponse response, Object handler) throws Exception {
- // TODO Auto-generated method stub
- return false;
- }
- /**
- * 这个方法只会在当前这个Interceptor的preHandle方法返回值为true的时候才会执行。postHandle是进行处理器拦截用的,它的执行时间是在处理器进行处理之
- * 后,也就是在Controller的方法调用之后执行,但是它会在DispatcherServlet进行视图的渲染之前执行,也就是说在这个方法中你可以对ModelAndView进行操
- * 作。这个方法的链式结构跟正常访问的方向是相反的,也就是说先声明的Interceptor拦截器该方法反而会后调用,这跟Struts2里面的拦截器的执行过程有点像,
- * 只是Struts2里面的intercept方法中要手动的调用ActionInvocation的invoke方法,Struts2中调用ActionInvocation的invoke方法就是调用下一个Interceptor
- * 或者是调用action,然后要在Interceptor之前调用的内容都写在调用invoke之前,要在Interceptor之后调用的内容都写在调用invoke方法之后。
- */
- @Override
- public void postHandle(HttpServletRequest request,
- HttpServletResponse response, Object handler,
- ModelAndView modelAndView) throws Exception {
- // TODO Auto-generated method stub
- }
- /**
- * 该方法也是需要当前对应的Interceptor的preHandle方法的返回值为true时才会执行。该方法将在整个请求完成之后,也就是DispatcherServlet渲染了视图执行,
- * 这个方法的主要作用是用于清理资源的,当然这个方法也只能在当前这个Interceptor的preHandle方法的返回值为true时才会执行。
- */
- @Override
- public void afterCompletion(HttpServletRequest request,
- HttpServletResponse response, Object handler, Exception ex)
- throws Exception {
- // TODO Auto-generated method stub
- }
- <beans xmlns="http://www.springframework.org/schema/beans"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
- xmlns:mvc="http://www.springframework.org/schema/mvc"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
- http://www.springframework.org/schema/context
- http://www.springframework.org/schema/context/spring-context-3.0.xsd
- http://www.springframework.org/schema/mvc
- http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">
这样在SpringMVC的配置文件中就可以使用mvc标签了,mvc标签中有一个mvc:interceptors是用于声明SpringMVC的拦截器的。
(二)使用mvc:interceptors标签来声明需要加入到SpringMVC拦截器链中的拦截器
- <mvc:interceptors>
- <!-- 使用bean定义一个Interceptor,直接定义在mvc:interceptors根下面的Interceptor将拦截所有的请求 -->
- <bean class="com.host.app.web.interceptor.AllInterceptor"/>
- <mvc:interceptor>
- <mvc:mapping path="/test/number.do"/>
- <!-- 定义在mvc:interceptor下面的表示是对特定的请求才进行拦截的 -->
- <bean class="com.host.app.web.interceptor.LoginInterceptor"/>
- </mvc:interceptor>
- </mvc:interceptors>
由上面的示例可以看出可以利用mvc:interceptors标签声明一系列的拦截器,然后它们就可以形成一个拦截器链,拦截器的执行顺序是按声明的先后顺序执行的,先声明的拦截器中的preHandle方法会先执行,然而它的postHandle方法和afterCompletion方法却会后执行。
在mvc:interceptors标签下声明interceptor主要有两种方式:
(1)直接定义一个Interceptor实现类的bean对象。使用这种方式声明的Interceptor拦截器将会对所有的请求进行拦截。
(2)使用mvc:interceptor标签进行声明。使用这种方式进行声明的Interceptor可以通过mvc:mapping子标签来定义需要进行拦截的请求路径。
经过上述两步之后,定义的拦截器就会发生作用对特定的请求进行拦截了。
相关推荐
Aspect是AOP的核心概念,它封装了关注点,使得我们可以将这些关注点与业务逻辑解耦。在Spring Boot中,AOP可以通过Spring的AspectJ库来实现。 首先,我们来看看标题提到的"Interceptor",这是Spring MVC中的一个...
Interceptor 的概念源于AOP(Aspect-Oriented Programming,面向切面编程)。面向切面编程是一种编程范式,它旨在减少代码重复,并将横切关注点(如日志记录、事务管理、权限验证等)从业务逻辑中分离出来。通过这种...
例如,在Spring框架中,我们可以使用`@Aspect`注解定义切面,使用`@Before`、`@After`、`@Around`等注解声明拦截器。 总之,Interceptor框架的实现依赖于Java的代理和反射技术,它可以方便地插入额外的逻辑到方法...
springboot框架demo,其中包含了filter、Interceptor、Aspect以及注解形式的aspect,以及对应的get和post接口,配置好了可以直接跑,省的再自己去搜索进行配置了,用来学习过滤器,拦截器和切面的配置以及执行顺序非常...
在Spring Boot应用中,过滤器(Filter)、拦截器(Interceptor)和切面(Aspect)都是实现请求处理逻辑增强的重要手段,而定时任务则用于执行周期性的后台任务。下面将详细介绍这些概念及其用法。 1. **Spring Boot...
Java拦截器(Interceptor)是Java应用开发中一种重要的设计模式,尤其在企业级应用和框架中,如Spring、Struts2、MyBatis等。它主要用于在方法执行前后添加额外的功能,比如日志记录、性能统计、事务管理、权限验证...
- **AOP设计模式**:Struts2的拦截器体系采用的是面向切面编程(Aspect-Oriented Programming, AOP)的设计模式。AOP是一种软件设计思想,它允许将横切关注点(Cross-cutting Concerns)从业务逻辑中分离出来。 ###...
拦截器(Interceptor)是面向切面编程(AOP,Aspect-Oriented Programming)中的一个重要概念。它可以被理解为一段能够控制程序流程的代码块,通过定义特定的“织入点”(即程序执行的某个位置),可以在这些位置前...
**拦截器**(Interceptor)是一种软件设计模式,尤其在面向切面编程(AOP,Aspect-Oriented Programming)领域中有着广泛的应用。其核心作用是在某个方法或字段被访问之前进行拦截,从而在访问前或访问后加入特定的...
在现代软件开发过程中,特别是Web应用程序中,为了实现灵活高效的业务逻辑处理及控制流管理,常常会使用到两种设计模式:拦截器(Interceptor)与过滤器(Filter)。这两种技术虽然在功能上有一定的相似之处,但其...
首先,我们需要理解 Castle AOP 的核心组件,即拦截器(Interceptor)和代理(Proxy)。拦截器是执行特定任务的类,而代理则是被拦截对象的包装器,它在调用实际方法之前和之后执行拦截器的逻辑。 **1. 创建拦截器*...
.NET动态代理AOP拦截是一种在.NET环境中实现面向切面编程(Aspect-Oriented Programming, AOP)的技术。AOP的核心思想是将业务逻辑与横切关注点(如日志、事务管理、性能监控等)解耦,使得代码更加模块化和可维护。...
自定义拦截器需要继承`org.apache.struts2.interceptor.Interceptor`接口或实现`com.opensymphony.xwork2.interceptor.Interceptor`抽象类,并实现相应的拦截方法。 6. **AOP的优势**: - AOP使开发者能够将关注点...
在Struts1中,拦截器(Interceptor)扮演着重要的角色,它们是实现业务逻辑和控制器之间解耦的关键组件。拦截器可以拦截用户的请求,执行预处理或者后处理操作,如日志记录、权限检查等,而无需在每个Action中重复...
在Main方法中,通过动态创建并使用FoobarProxy实例,可以观察到Interceptor.Injected属性的变化,从而验证拦截的成功。 2. **Reflection.Emit** Reflection.Emit 类库提供了另一种动态生成IL代码的方法。与IL Emit...
3. **拦截器实现**:自定义Interceptor类,继承自AbstractInterceptor或实现IInterceptor接口,定义拦截逻辑。 4. **切面应用**:通过Castle的AspectKernel或AspectConfiguration设置,将拦截器应用到目标类的方法上...
另一种是对方法的拦截,需要使用@Aspect注解,在每次调用指定方法的前、后进行拦截。 Interceptor的配置: Interceptor的配置可以通过在springmvc配置文件中添加节点来实现,例如:<mvc:interceptors> ...
- **Interceptor**:类似于Advice,但在Spring AOP中通常用于实现特定的拦截器。 3. **配置示例**: ```xml <aop:aspect id="logAspect" ref="loggerBean"> (* com.example.service.*.*(..))"/> (* ...
在J2EE应用程序开发中,拦截器(Interceptor)、切入点(Pointcut)和代理(Proxy)是Spring框架中的重要概念,它们对于实现灵活的控制流程、事务管理、日志记录等功能起到关键作用。以下是对这些概念的详细解释: ...
在Java开发中,拦截器(Interceptor)是一种设计模式,它允许开发者在某个方法或运算执行前后插入自定义的行为。这通常用于实现日志记录、事务管理、权限验证等任务,而无需修改目标方法的源码。Java的拦截器机制...