spring aop 通知简单例子

 

 

package cn.itcast.service;

import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;


@Aspect
public class MyInterceptor {
 
 @Pointcut("execution(* cn.itcast.service.impl.PersonServiceBean.*(..))")
 private void anyMethod()
 {
  System.out.println("切面-----");
 }
 
 @Before("anyMethod()")
 public void doAccessCheck()
 {
  System.out.println("前置通知"); 
 }
 
 //@AfterReturning(pointcut="anyMethod()",returning="result")
 public void doAfterReturning(String result)
 {
 System.out.println("后置通知"+result); 
 }
 
 public void doAfter()
 {
  System.out.println("最终通知");
 }
 
 public void doAfterThrowing()
 {
  System.out.println("例外通知");
 }
 
 //@Around("anyMethod()")
 public Object doBasicProfiling(ProceedingJoinPoint pjp) throws Throwable
 {
  System.out.println("进入方法");
  Object result=pjp.proceed();
  System.out.println("退出方法");
  return result;
  
 }
}


/**

//@Aspect
public class MyInterceptor {

 //@Pointcut("execution(* cn.itcast.service.impl.PersonServiceBean.*(..))")
 //private void anyMethod()
 //{
  //System.out.println("切面-----");
 //}
 //@Before("anyMethod() && args(name)")
 public void doAccessCheck(String name)
 {
  System.out.println("前置通知"+name); 
 }
 
 //@AfterReturning(pointcut="anyMethod()",returning="result")
 public void doAfterReturning(String result)
 {
 System.out.println("后置通知"+result); 
 }
 
 public void doAfter()
 {
  System.out.println("最终通知");
 }
 
 public void doAfterThrowing()
 {
  System.out.println("例外通知");
 }
 
 //@Around("anyMethod()")
 public Object doBasicProfiling(ProceedingJoinPoint pjp) throws Throwable
 {
  System.out.println("进入方法");
  Object result=pjp.proceed();
  System.out.println("退出方法");
  return result;
  
 }
}


**/

-----------------------------

package cn.itcast.service;

import java.util.List;
import java.util.Map;
import java.util.Properties;
import java.util.Set;

public interface PersonService {
 
 public void save(String name);
 public void update(String name, Integer personid);
 public String getPersonName(Integer personid);
 

}

-------------------------------------

package cn.itcast.service.impl;

import cn.itcast.service.PersonService;

public class PersonServiceBean implements PersonService {
 
 
 public String getPersonName(Integer personid) {
  System.out.println("------这是getPersonName方法");
  return "xxx";
 }

 public void save(String name) {
  //throw new RuntimeException("我爱例外");
  System.out.println("------这是save方法");
 }

 public void update(String name, Integer personid) {
  
  System.out.println("------这是update方法");
  
 }
 
 

 
 
 
 


}

---------------------------------------

<?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:context="http://www.springframework.org/schema/context"
       xmlns:aop="http://www.springframework.org/schema/aop"     
       xsi:schemaLocation="http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
           http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd
           http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd">
        <aop:aspectj-autoproxy/>
       
        <bean id="myInterceptor" class="cn.itcast.service.MyInterceptor"/>
       
       
        <bean id="personService" class="cn.itcast.service.impl.PersonServiceBean"></bean>
       
    
</beans>

 

 

--------------------

package test;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

import cn.itcast.service.PersonService;

 

public class Test {

 /**
  * @param args
  */
 public static void main(String[] args) {
  ApplicationContext cxt = new ClassPathXmlApplicationContext("app.xml");
  PersonService p = (PersonService)cxt.getBean("personService");
  p.save("222");
  //p.getPersonName(222);
  
  
  
}
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值