【问题标题】:Unable to retrieve private annotation via reflection from aspectj advice无法通过 aspectj 建议的反射检索私有注释
【发布时间】:2011-06-16 16:46:49
【问题描述】:

我有一个注释,定义如下:

public @interface RestletResourceVariable {
    String name(); 
}

我有一个这样定义的 restlet ServerResource:

public class QuestionResource extends ServerResource {
    static Logger logger = LoggerFactory.getLogger(QuestionResource.class);

    @RestletResourceVariable(name="questionId")
    public String questionId; 

    @Get("json")
    public JsonRepresentation doGet() {
        logger.info("QuestionResource::doGet()");

        return new JsonRepresentation("{ nil };");
    }

    @Post
    public Representation doPost(Representation entity) throws Exception {
        logger.info("QuestionResource::doPost:" + entity.getText());
        return null;
    }
}

这是我的方面:

public aspect RestletResourceVariableAspect { 
    static Logger logger = LoggerFactory.getLogger(RestletResourceVariableAspect.class); 

    pointcut RESTMethods() :
        execution( @org.restlet.resource.Delete * packagename..*(..) ) ||
        execution( @org.restlet.resource.Get    * packagename..*(..) ) || 
        execution( @org.restlet.resource.Post   * packagename..*(..) ) || 
        execution( @org.restlet.resource.Put    * packagename..*(..) ) 
        ;

    before(): RESTMethods() {
        Signature sig = thisJoinPoint.getSignature();

        Object target = thisJoinPoint.getTarget();
        Class<?> c = target.getClass();
        Class<?> cdecl = sig.getDeclaringType(); 

        logger.info("Class name: {} cdecl {}", c.getName(), cdecl.getName());
        logger.info("Sig: {} in class {}", sig.getName(),sig.getDeclaringType().getName());
        Field[] fields = cdecl.getDeclaredFields() ;
        for ( Field field : fields ) {
            logger.info("Field name: {}", field.getName());
            Annotation[] annotations = field.getDeclaredAnnotations();
            logger.info("Annotations {} length {}", annotations, Integer.toString(annotations.length));
            for(Annotation annotation : annotations){

                if(annotation instanceof RestletResourceVariable){
                    RestletResourceVariable myAnnotation = (RestletResourceVariable) annotation;
                    System.out.println("name: " + myAnnotation.name());
                }
            }

        }
    }
}

我得到这样的输出:

16:22:11.656 [24864323@qtp-6011238-0] INFO  RestletResourceVariableAspect - Class name: QuestionResource cdecl QuestionResource
16:22:11.656 [24864323@qtp-6011238-0] INFO  RestletResourceVariableAspect - Sig: doGet in class QuestionResource
16:22:11.656 [24864323@qtp-6011238-0] INFO  RestletResourceVariableAspect - Field name: logger
16:22:11.656 [24864323@qtp-6011238-0] INFO  RestletResourceVariableAspect - Annotations [] length 0
16:22:11.656 [24864323@qtp-6011238-0] INFO  RestletResourceVariableAspect - Field name: questionId
16:22:11.656 [24864323@qtp-6011238-0] INFO  RestletResourceVariableAspect - Annotations [] length 0
16:22:11.656 [24864323@qtp-6011238-0] INFO  RestletResourceVariableAspect - Field name: ajc$tjp_0
16:22:11.656 [24864323@qtp-6011238-0] INFO  RestletResourceVariableAspect - Annotations [] length 0
16:22:11.656 [24864323@qtp-6011238-0] INFO  RestletResourceVariableAspect - Field name: ajc$tjp_1
16:22:11.656 [24864323@qtp-6011238-0] INFO  RestletResourceVariableAspect - Annotations [] length 0
16:22:11.656 [24864323@qtp-6011238-0] INFO  QuestionResource - QuestionResource::doGet()

关于我做错了什么的任何指导?我想找到标有注释的字段,以便我可以根据要求填充它们。

【问题讨论】:

    标签: java reflection annotations aspectj restlet


    【解决方案1】:

    确保将@Retention(RetentionPolicy.RUNTIME) 添加到注释定义中,如下所示:

    @Retention(RetentionPolicy.RUNTIME) 
    @Target ({ElementType.FIELD, ElementType.METHOD })
    @Inherited
    public @interface RestletResourceVariable {
        String name(); 
    }
    

    【讨论】:

    • 你最棒了!谢谢!
    猜你喜欢
    • 1970-01-01
    • 2023-03-21
    • 2012-04-02
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-01-20
    相关资源
    最近更新 更多