spring中自定义注解(annotation)与AOP中获取注解

1、自定义注解(annotation)java

自定义注解的做用:在反射中获取注解,以取得注解修饰的类、方法或属性的相关解释。
spring

package me.lichunlong.spring.annotation;

import java.lang.annotation.Documented;   
import java.lang.annotation.ElementType;   
import java.lang.annotation.Retention;   
import java.lang.annotation.RetentionPolicy;   
import java.lang.annotation.Target;   
spring-mvc

//自定义注解相关设置
@Target({ElementType.METHOD})   
@Retention(RetentionPolicy.RUNTIME)   
@Documented 

public @interface LogAnnotation {   
mvc

//自定义注解的属性,default是设置默认值
    String desc() default "无描述信息";   
}  
this


2、自定义注解的使用spa

package me.lichunlong.spring.service;

import me.lichunlong.spring.annotation.LogAnnotation;
import me.lichunlong.spring.jdbc.JdbcUtil;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

@Service
public class UserService {
 //与其它注解同样的使用
    @LogAnnotation(desc="this is UserService")
    public void add() {
        System.out.println("UserService add...");
    }
}
.net





3、AOP中获取注解
代理

//    环绕通知:相似与动态代理的全过程
//    携带参数ProceedingJoinPoint,且必须有返回值,即目标方法的返回
    @Around(value = "execution(* me.lichunlong.spring.service.*.*(..)) && @annotation(log)")
    public Object aroundMethod(ProceedingJoinPoint pjd, LogAnnotation log) {
        Object result = null;
        System.out.println(log.desc());
        try {
            System.out.println("前置通知");
            result = pjd.proceed();
            System.out.println("后置通知");
        } catch (Throwable e) {
            System.out.println("异常通知");
        }
        System.out.println("返回通知");
        return result;
    }
code

4、配置扫描aoporm

<aop:aspectj-autoproxy proxy-target-class="true"/>

5、解决在Controller中注解不生效

    通常aop扫描是配置到ApplicationContext.xml,嘿嘿,问题就在这!Spring MVC加载的WebApplicationContext而不是ApplicationContext,因此应该把schema和加载加到 spring-mvc.xml,而后?一切正常。

相关文章
相关标签/搜索