1、添加其他jar包
2、配置applicationContext.xml文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
<?
xml
version
=
"1.0"
encoding
=
"UTF-8"
?>
xsi:schemaLocation="http://www.springframework.org/schema/beans
<
context:annotation-config
/>
<
context:component-scan
base-package
=
"com.fz.annotation"
/>
<
aop:aspectj-autoproxy
/>
</
beans
>
|
3、编写切面类LogInterceptor.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
package
com.fz.annotation.aop;
import
org.aspectj.lang.ProceedingJoinPoint;
import
org.aspectj.lang.annotation.AfterReturning;
import
org.aspectj.lang.annotation.AfterThrowing;
import
org.aspectj.lang.annotation.Around;
import
org.aspectj.lang.annotation.Aspect;
import
org.aspectj.lang.annotation.Before;
import
org.aspectj.lang.annotation.Pointcut;
import
org.springframework.stereotype.Component;
@Aspect
@Component
public
class
LogInterceptor {
@Pointcut
(
"execution(public void com.fz.annotation.service.impl.UserServiceImpl.userAdd(com.fz.xml.entity.User))"
)
public
void
myMethod(){};
@Before
(
"myMethod()"
)
public
void
before(){
System.out.println(
"方法之前执行...."
);
}
@AfterReturning
(
"myMethod()"
)
public
void
afterRutting(){
System.out.println(
"方法正常执行之后...."
);
}
@AfterThrowing
(
"myMethod()"
)
public
void
afterThrowing(){
System.out.println(
"方法抛出异常之后...."
);
}
@Around
(
"myMethod()"
)
public
void
around(ProceedingJoinPoint pjp)
throws
Throwable{
System.out.println(
"方法执之前around......"
);
//这里会优先于@Before先执行
pjp.proceed();
//向下继续方法的执行:(包括执行其他切面的拦截,如果当中抛出异常,则不会向下继续执行)
System.out.println(
"方法执之后around......"
);
//这里会在@AfterReturning执行之后执行
}
}
|