Spring AOP使用@Around环绕切面,我sb地竟然影响实际业务了

本文记录了一次在使用Spring AOP的@Around注解进行环绕切面处理时,由于不当操作导致业务受到影响的问题。作者在切面中尝试获取请求参数并写入ES日志,过程中遇到异常,错误地认为全局try-catch可以避免影响业务,但忽略了环绕切面的返回值。通过逐步优化,将异常处理和业务执行分离,确保日志记录的同时不影响正常流程。总结中提到,这样的处理方式目前看来尚无问题,但作者也在反思如何更合适地编写AOP切面。
摘要由CSDN通过智能技术生成

一、切面把与第三方交互的信息写进ES日志,需要用到环绕增强,但是由于切面出错,竟然把实际业务给影响了,做下笔记,以免后犯。

1、切面中如以下方法,由于要获取请求方法参数,但是未处理参数中有request或者response或者其它的特别请求,在
JSON.toJSONString(“日志写请求参数”)时报错
java.lang.IllegalStateException: It is illegal to call this method if the current request is not in asynchronous mode (i.e. isAsyncStarted() returns false)

public Map createOrder(HttpServletRequest request, 
@RequestBody String body, @RequestHeader("token") String token) {
   

2、修改时,我在环绕切面这个大方法直接用try catch全包着,我sb的以为这样就不影响实际业务了,但是报错的地方在调用proceed()方法之前,这样还没执行实际业务就抛错了。

@Around("pointCut()")
public Object handle(ProceedingJoinPoint joinPoint) throws Throwable {
   
	Object result = null;
	try {
   
		long begin = System.currentTimeMillis();
		HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes())
				.getRequest();
		// IP地址
		String ipAddr = getRemoteHost(request);
		// 第三方发过来的url其实已经被我们转过了
		// String url = request.getRequestURL().toString();
		String url = "http://127.0.0.1";

		Signature signature = joinPoint.getSignature();
		Object obj = joinPoint.getTarget();
		MethodSignature methodSignature = (MethodSignature) signature;
		Method targetMethod = methodSignature.getMethod();

		// 去除参数中有HttpServletRequest或者HttpServletResponse的参数
		Object[] args = joinPoint.getArgs();
		Stream<?> stream = ArrayUtils.isEmpty(args) ? Stream.empty() 
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值