12

我是 AOP 的新手。我遇到了这样的问题。

package org.suman.Aspect;

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

@Aspect
public class LoginAspect {
    //@Before("execution(public String getName())")
    //@Before("execution(public String org.suman.Model.Triangle.getName())")
    //@Before("execution(* get*())")
    //@Before("execution(* get*(..))")
    //@Before("execution(* org.suman.Model.*.get*())")

    //@Before("execution(* get*())&& within(org.suman.Model.Circle)")
    @Before("execution(* get*())&& allCircle()")
    //@Before("allGetters() && allCircle()")
    public void LoginAdvice()
    {
        System.out.println("Advice run.. getMethod is called");
    }

    @Before("execution(* get*())")
    //@Before("allGetters()")
    public void SecondAdvice()
    {
        System.out.println("this is a second Advice");
    }
    @Pointcut("execution(* get*())")
    public void allGetters(){}

    //@Pointcut("execution (* * org.suman.Model.Circle.*(..))")
    @Pointcut("within(org.suman.Model.Circle)")
    public void allCircle(){}

} 

使用切入点时,方法allGetters()LoginAdvice方法,如果我使用 @Before("execution(* get*())")则没有错误,但如果我使用@Before("allGetters()")则给出错误

java.lang.IllegalArgumentException: ::0 处的错误找不到引用的切入点 allGetters

如果我使用@Before("execution(* get*())&& within(org.suman.Model.Circle)")而不是方法名称,它会起作用。

我的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"
    xmlns:context="http://www.springframework.org/schema/context"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd">
    <!-- <context:annotation-config /> -->
    <aop:aspectj-autoproxy />

    <bean name="triangle" class="org.suman.Model.Triangle">
        <property name="name" value="Triangle Name"></property>
    </bean>
    <bean name="circle" class="org.suman.Model.Circle">
        <property name="name" value="Circle name"></property>
    </bean>
    <bean name="shapeService" class="org.suman.Services.ShapeService"
        autowire="byName"></bean>
    <bean name="loginAspect" class="org.suman.Aspect.LoginAspect"></bean>

</beans>

请用切入点解决问题

4

13 回答 13

27

我遇到了这个问题 - 在“占位符”方法上使用 @Pointcut 会给我“找不到引用的切入点”错误。

只需通过使用以下 maven 依赖项更新 AspectJ 库即可解决:

    <dependency>
        <groupId>org.aspectj</groupId>
        <artifactId>aspectjrt</artifactId>
        <version>1.5.4</version>
    </dependency>
    <dependency>
        <groupId>org.aspectj</groupId>
        <artifactId>aspectjweaver</artifactId>
        <version>1.5.4</version>
    </dependency>

对此

    <dependency>
        <groupId>org.aspectj</groupId>
        <artifactId>aspectjrt</artifactId>
        <version>1.7.0</version>
    </dependency>
    <dependency>
        <groupId>org.aspectj</groupId>
        <artifactId>aspectjweaver</artifactId>
        <version>1.7.0</version>
    </dependency>
于 2012-09-27T20:46:28.490 回答
3

我遇到了同样的问题。一旦我用 aspectjweaver-1.6.11.M2.jar 版本替换了 aspectjweaver。一切都开始顺利进行。

于 2013-01-29T00:44:12.087 回答
2

使用 aspectjweaver 和 aspectjrt 版本 1.8.10

于 2018-04-15T16:04:48.140 回答
2

运行早期访问版本的 JDK9 也可能导致该问题。

Maven 可能更喜欢更新版本的 Java,而不是PATH.

就我而言,我在 Ubuntu 15.04 上通过 Maven 使用 Swagger2 运行 Spring,并且我已经安装了java-8-oraclejava-9-oracle(以及更多版本)。我的java -version,源自PATH,说1.8.0_72,但是当我运行 Maven 并更改为时/usr/bin/mvnecho JAVA_HOME它显示已选择/usr/lib/jvm/java-9-oracle

导出JAVA_HOME/usr/lib/jvm/java-8-oracle使 Maven 使用所需的 Java 版本,这使得 AOP 编织 Spring 的依赖注入布线的切入点的问题消失了。

于 2016-01-27T17:41:25.467 回答
1

在不同的用例中遇到相同的错误。

在此处输入图像描述

用例:试图调用存在于不同方面类中的切入点。

LogServicePointCut1() 切入点存在于 LogService

package com.opensource.kms;
@Aspect
@Component
public class LogService {
    
    @Pointcut("execution(* com.opensource.kms.AccountService.my*(..))")
    public void logServicePointCut1() {
    }
}

尝试调用 SecurityService

@Aspect
@Component
public class SecurityService {

    @Before("logServicePointCut1()")  /*Need to give fully Qualified name*/
    public void verifyUserBeforeSecurityService() {
        System.out.println("verifyUserBeforeSecurityService");
    }
}

解决方案:需要通过全限定名com.opensource.kms.LogService.logServicePointCut1( )

希望这对某人有帮助!

于 2020-05-01T09:06:57.320 回答
0

You should change the aspectJWeaver version to be 1.6.x

于 2012-08-04T19:26:27.423 回答
0

我相信你需要在前面加上另一个通配符:

@Pointcut("execution(* get*())")

将其更改为:

@Pointcut("execution(* *get*())")
于 2012-05-07T13:07:36.673 回答
0

添加这个 Maven 依赖项。这将解决您的问题。

将版本更改为1.6.12

于 2019-08-23T06:52:45.210 回答
0

这是依赖关系的问题。应使用以下完全相同版本的 jar 或依赖项来避免此类问题:

<dependency>
<groupId>aspectj</groupId>
<artifactId>aspectjrt</artifactId>
<version>1.5.2</version>
</dependency>

<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
<version>1.8.10</version>
</dependency>

<dependency>
<groupId>asm</groupId>
<artifactId>asm</artifactId>
<version>3.3.1</version>
</dependency>

<dependency>
<groupId>aopalliance</groupId>
<artifactId>aopalliance</artifactId>
<version>1.0</version>
</dependency>

<dependency>
<groupId>cglib</groupId>
<artifactId>cglib</artifactId>
<version>2.2.2</version>
</dependency>
于 2019-03-13T14:22:23.227 回答
0

我也遇到了类似的问题,@Before 建议不接受 @Pointcut 方法名称作为参数。我通过将依赖项版本更改为:

<dependency>
    <groupId>org.aspectj</groupId>
    <artifactId>aspectjrt</artifactId>
    <version>1.6.11</version>
</dependency>

<!-- https://mvnrepository.com/artifact/org.aspectj/aspectjweaver -->
<dependency>
    <groupId>org.aspectj</groupId>
    <artifactId>aspectjweaver</artifactId>
    <version>1.6.11</version>
</dependency>

它现在对我来说工作正常。

于 2018-01-24T09:31:12.643 回答
0

我遇到了这个问题,因为项目是在 Java 1.6 中编译的,但是 tomcat 服务器是在 Java 8 中启动的。

于 2017-05-22T17:55:27.220 回答
0

请使用以下 Maven 依赖项 - 我希望它会起作用

  1. 方面jrt 1.8.14
  2. aspectjweaver 1.8.14
<dependency>
    <groupId>org.aspectj</groupId>
    <artifactId>aspectjrt</artifactId>
    <version>1.8.14</version>
</dependency>

<dependency>
    <groupId>org.aspectj</groupId>
    <artifactId>aspectjweaver</artifactId>
    <version>1.8.14</version>
    <scope>runtime</scope>
</dependency>
于 2021-01-08T19:09:31.840 回答
-1

将 aspectjeaver 版本更改为最新版本并部署它...

于 2012-08-03T08:43:53.000 回答