spring - Spring Boot @Aspect 日志记录
问题描述
我尝试使用@Aspect 记录所有请求和响应。如果我的端点有 @RequestBody 我的代码正在工作,但我的 get 端点没有 @RequestBody 并且我看不到日志。这是对这种情况的任何解释吗?
我的课就是这样;
@Aspect
@Component
@Slf4j
@RequiredArgsConstructor(onConstructor = @__({@Autowired, @NotNull}))
public class AspectLogging {
private final ObjectMapper objectMapper;
@Pointcut("@annotation(org.springframework.web.bind.annotation.GetMapping) || @annotation(org.springframework.web.bind.annotation.PostMapping)")
public void annotationPointCutDefinition() {
}
@Pointcut("execution(* *(com.dux.secondwallet.api.v3.pay.merchant.*))")
public void atExecution() {
}
@Before("annotationPointCutDefinition() && atExecution()")
public void endpointBefore(JoinPoint p) {
Object[] signatureArgs = p.getArgs();
if (Objects.nonNull(signatureArgs) && signatureArgs.length > 0) {
log.info("Request object: " + signatureArgs[0]);
}
}
@AfterReturning(pointcut = "annotationPointCutDefinition() && atExecution()", returning = "returnValue")
public void endpointAfterReturning(Object returnValue) {
try {
log.info("Response object:" + objectMapper.writeValueAsString(returnValue));
} catch (JsonProcessingException e) {
log.error(e.getMessage(), e);
}
}
@AfterThrowing(pointcut = "annotationPointCutDefinition() && atExecution()", throwing = "e")
public void endpointAfterThrowing(JoinPoint p, Exception e) throws Exception {
e.printStackTrace();
log.error(p.getTarget().getClass().getSimpleName() + " " + p.getSignature().getName() + " " + e.getMessage());
}
}
示例控制器;getRequest 方法不记录,postRequest 记录。
@Slf4j
@RestController
@RequestMapping("/v3/")
public class MyController {
@GetMapping("/balances")//not before and after logging
public List<java.lang.String> getRequest() {
return Collections.singletonList("TEST");
}
@PostMapping("/limits")//its logging
public TransactionLimitResponse postRequest(@Valid @RequestBody TransactionLimitRequest transactionLimitRequest) {
return TransactionLimitResponse.builder()
.currency("EUR")
.type("TYPE")
.min(100)
.max(1000)
.build();
}
}
解决方案
首先我想问你你想记录什么?
您的方面代码的目的是记录方法参数,并且您在 @GetMapping 方法上没有任何参数。
所以你的方面方法也成功触发了@GetMapping。但只需检查条件并通过它。看不到日志是很正常的。
应用下面的更改它将起作用:
@Pointcut("@annotation(org.springframework.web.bind.annotation.GetMapping)")
//@Pointcut("@annotation(org.springframework.web.bind.annotation.GetMapping) || @annotation(org.springframework.web.bind.annotation.PostMapping))")
public void getMapping() {
}
@Pointcut("@annotation(org.springframework.web.bind.annotation.PostMapping)")
//@Pointcut("@annotation(org.springframework.web.bind.annotation.GetMapping) || @annotation(org.springframework.web.bind.annotation.PostMapping))")
public void postMapping() {
}
@Pointcut("execution(* *(..)) && within(com.dux.secondwallet.api.v3.pay.merchant.*))")
public void atExecution() {
}
@Before("(getMapping() || postMapping()) && atExecution()")
public void endpointBefore(JoinPoint p) {
log.info("ssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssssss");
Object[] signatureArgs = p.getArgs();
if (Objects.nonNull(signatureArgs) && signatureArgs.length > 0) {
log.info("Request object: " + signatureArgs[0]);
}else{
log.info("log for get");
}
}
execution(* *(..))
:这是为您的方法签名。
within(com.dux.secondwallet.api.v3.pay.merchant.*)
这是包裹限制。
推荐阅读
- docker - 将设备添加到 docker 容器时如何转义冒号?
- c# - Customer 类的装饰器模式
- javascript - 如何通过类对象阻止一个函数与另一个函数一起运行
- wordpress - 我制作了一个多步骤幻灯片来购买产品(现在我想将它与 woocommerce 链接)
- visual-studio-code - 如何创建默认任务?
- javascript - 如何从引导下拉列表中检索所选选项的 ID?
- r - 根据列号和单独的索引向量替换数据表中的值
- javascript - 由于“没有函数对象”,Onchange 事件无法打开 JavaScript 函数
- java - 如何为 tomcat 配置 maven-war-plugin
- javascript - 如何在 pug/Jade 中关闭浏览器窗口