带注释参数的切入点匹配方法 - java

如果满足以下条件,则需要创建一个与方法匹配的切入点的方面:

  • 是公开的
  • 其类使用@Controller注释(最后没有)
  • 它的参数之一(可以有多个)用@MyParamAnnotation注释。
  • 我认为前两个条件很容易,但是我不知道用Spring完成第三个条件是否可行。如果不是,也许我可以将其更改为:

  • 其参数之一是com.me.MyType类型的实例(或实现某些接口)
  • 您认为有可能实现这一目标吗?而且性能会好吗?

    谢谢

    编辑:匹配方法的一个示例。如您所见,MyMethod未被注释(但可以被注释)。

    @Controller
    public class MyClass {
        public void MyMethod (String arg0, @MyParamAnnotation Object arg1, Long arg3) {
            ...
        }
    }
    

    编辑:我最终基于@Espen答案使用的解决方案。如您所见,我稍微改变了条件:类实际上不必是@Controller。

    @Around("execution(public * * (.., @SessionInject (*), ..))")
    public void methodAround(JoinPoint joinPoint) throws Exception {
        ...
    }
    

    参考方案

    这是一个有趣的问题,因此我创建了一个小示例应用程序来解决该问题! (并在随后通过Sinuhe的反馈进行了改进。)

    我创建了一个DemoController类,应作为该方面的示例:

    @Controller
    public class DemoController {
    
        public void soSomething(String s, @MyParamAnnotation Double d, Integer i) {
        }
    
        public void doSomething(String s, long l, @MyParamAnnotation int i) {
        }
    
        public void doSomething(@MyParamAnnotation String s) {
        }
    
        public void doSomething(long l) {
        }
    }
    

    将在前三个方法上添加连接点的方面,但不会在未使用@MyParamAnnotation注释参数的最后一个方法上添加连接点的方面:

    @Aspect
    public class ParameterAspect {
    
        @Pointcut("within(@org.springframework.stereotype.Controller *)")
        public void beanAnnotatedWithAtController() {
        }
    
        @Pointcut("execution(public * *(.., @aspects.MyParamAnnotation (*), ..))")
        public void methodWithAnnotationOnAtLeastOneParameter() {
        }
    
        @Before("beanAnnotatedWithAtController() " 
                + "&& methodWithAnnotationOnAtLeastOneParameter()")
        public void beforeMethod() {    
            System.out.println("At least one of the parameters are " 
                      + "annotated with @MyParamAnnotation");
        }
    }
    

    第一个切入点将在标记有@Controller的类内的所有方法上创建一个连接点。

    满足以下条件时,第二个切入点将添加一个连接点:

  • 公共方法
  • first *是每种返回类型的通配符。
  • 第二个*是所有类中所有方法的通配符。
  • (..,在带注释的参数之前将零与许多任何类型的参数匹配。
  • @aspects.MyParamAnnotation (*),与使用给定注释注释的参数匹配。
  • ..)在带注释的参数之后将零与许多任何类型的参数匹配。
  • 最后,@Before建议会建议所有两个切入点均满足所有条件的方法。

    切入点可与AspectJ和Spring AOP一起使用!

    在性能方面。开销很小,尤其是对于在编译时或加载时进行编织的AspectJ。

    Java-搜索字符串数组中的字符串 - java

    在Java中,我们是否有任何方法可以发现特定字符串是字符串数组的一部分。我可以避免出现一个循环。例如String [] array = {"AA","BB","CC" }; string x = "BB" 我想要一个if (some condition to tell wheth…

    Java:线程池如何将线程映射到可运行对象 - java

    试图绕过Java并发问题,并且很难理解线程池,线程以及它们正在执行的可运行“任务”之间的关系。如果我创建一个有10个线程的线程池,那么我是否必须将相同的任务传递给池中的每个线程,或者池化的线程实际上只是与任务无关的“工人无人机”可用于执行任何任务?无论哪种方式,Executor / ExecutorService如何将正确的任务分配给正确的线程? 参考方案 …

    JAVA:字节码和二进制有什么区别? - java

    java字节代码(已编译的语言,也称为目标代码)与机器代码(当前计算机的本机代码)之间有什么区别?我读过一些书,他们将字节码称为二进制指令,但我不知道为什么。 参考方案 字节码是独立于平台的,在Windows中运行的编译器编译的字节码仍将在linux / unix / mac中运行。机器代码是特定于平台的,如果在Windows x86中编译,则它将仅在Win…

    java:继承 - java

    有哪些替代继承的方法? java大神给出的解决方案 有效的Java:偏重于继承而不是继承。 (这实际上也来自“四人帮”)。他提出的理由是,如果扩展类未明确设计为继承,则继承会引起很多不正常的副作用。例如,对super.someMethod()的任何调用都可以引导您通过未知代码的意外路径。取而代之的是,持有对本来应该扩展的类的引用,然后委托给它。这是与Eric…

    Java:BigInteger,如何通过OutputStream编写它 - java

    我想将BigInteger写入文件。做这个的最好方式是什么。当然,我想从输入流中读取(使用程序,而不是人工)。我必须使用ObjectOutputStream还是有更好的方法?目的是使用尽可能少的字节。谢谢马丁 参考方案 Java序列化(ObjectOutputStream / ObjectInputStream)是将对象序列化为八位字节序列的一种通用方法。但…