SpringAOP 自定义2种拦截器

Student.java

	private Integer age;
	private String name;
	public void setAge(Integer age) {
	 this.age = age;
	}
	public Integer getAge() {
	 System.out.println("Age : " + age );
	 return age;
	}
	public void setName(String name) {
	 this.name = name;
	}
	public String getName() {
	 System.out.println("Name : " + name );
	 return name;
	}


Logging.java

	public void beforeAdvice(){
		 System.out.println("Going to setup student profile.");
	}
		
	public void afterAdvice(){
		 System.out.println("Student profile has been setup.");
	}

bean.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xmlns:aop="http://www.springframework.org/schema/aop"
 xsi:schemaLocation="http://www.springframework.org/schema/beans
 http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
 http://www.springframework.org/schema/aop
 http://www.springframework.org/schema/aop/spring-aop-3.0.xsd ">
    
    <aop:config>
	 <aop:aspect id="log" ref="logging">
	 <aop:pointcut id="selectAll"
	 	expression="execution(* com.lin.*.*(..))"/>
	 <aop:before pointcut-ref="selectAll" method="beforeAdvice"/>
	 <aop:after pointcut-ref="selectAll" method="afterAdvice"/>
	 
	 </aop:aspect>
 </aop:config>


 <!-- Definition for student bean -->
 <bean id="student" class="com.lin.Student">
	 <property name="name" value="Zara" />
	 <property name="age" value="11"/>
 </bean>
 <!-- Definition for logging aspect -->
 <bean id="logging" class="com.lin.Logging"/>
 
</beans>

测试代码

	@Test
	public void Test1(){
		ApplicationContext context = new ClassPathXmlApplicationContext("beans.xml");
		Student student = (Student) context.getBean("student");
		student.getName();
		student.getAge();
		//student.printThrowException();
	}


Loggin.java

@Pointcut("execution(* com.lin.*.*(..))")
 private void selectAll(){}

@Before("selectAll()")
public void beforeAdvice(){
	 System.out.println("Going to setup student profile.");
}

@After("selectAll()")
public void afterAdvice(){
	 System.out.println("Student profile has been setup.");
}

@AfterReturning(pointcut = "selectAll()", returning="retVal")
 public void afterReturningAdvice(Object retVal){
 System.out.println("Returning:" + retVal.toString() );
 }

bean.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xmlns:aop="http://www.springframework.org/schema/aop"
 xsi:schemaLocation="http://www.springframework.org/schema/beans
 http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
 http://www.springframework.org/schema/aop
 http://www.springframework.org/schema/aop/spring-aop-3.0.xsd ">
 <aop:aspectj-autoproxy/>
 <!-- Definition for student bean -->
 <bean id="student" class="com.lin.Student">
 <property name="name" value="Zara" />
 <property name="age" value="11"/>
 </bean>
 <!-- Definition for logging aspect -->
 <bean id="logging" class="com.lin.MyLogging"/>
</beans>

测试代码

@Test
	public void Test2() {
		ApplicationContext context =new ClassPathXmlApplicationContext("bean1.xml");
		Student student = (Student) context.getBean("student");
		student.getName();
		student.getAge();
		//student.printThrowException();
	}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值