首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为Spring JPA存储库方法配置Pointcut

为Spring JPA存储库方法配置Pointcut
EN

Stack Overflow用户
提问于 2019-10-15 18:22:52
回答 1查看 2.5K关注 0票数 4

我正在尝试创建一个方面,它在每次调用Spring的JpaRepository ()之后运行。我将我的方面定义如下:

代码语言:javascript
复制
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.AfterReturning;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

@Aspect
@Component
@Slf4j
public class ProcessAspect {

    @Autowired
    private ProcessService processService;

    @AfterReturning(value = "execution(* com.domain.control.repository.ProcessDao.save())))",
    returning = "result")
    private void propagateProcess(JoinPoint joinPoint, Object result) {
        log.info("Aspect is working, congratulations. Jointpoint {} , result {}", joinPoint, result.toString());
        Process process = (process) result;

       // do something on the object returned by save()
        processService.createOrUpdateProcess(process);
    }

}

我的仓库定义如下:

代码语言:javascript
复制
@Repository
public interface ProcessDao extends JpaRepository<Process, String>

如果我这样配置它,那么方面就不起作用了。

如何将我的方面配置为在通用JPA存储库方法之后运行?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-10-15 18:41:42

首先,您的ProcessDao没有save方法,所以它不匹配;其次,您有一个带有无参数save方法的切入点,但没有这样的东西。相反,您希望在切入点中使用一个Spring数据存储库类,并匹配1个参数。

像这样的东西

代码语言:javascript
复制
execution(* org.springframework.data.jpa.repository.JpaRepository+.save(..))))

或者让它更通用

代码语言:javascript
复制
execution(* org.springframework.data.repository.CrudRepository+.save(..))))

这将使您的切入点匹配。还有一个saveAllsaveAndFlush,所以如果需要拦截它们,您可能需要添加更多的切入点。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58392441

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档