天天看點

springboot @Aspect用法

1.pom檔案

<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>1.5.2.RELEASE</version>
	</parent>

	<dependencies>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-web</artifactId>
		</dependency>
		<!-- aop -->
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-aop</artifactId>
		</dependency>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-test</artifactId>
		</dependency>
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-test</artifactId>
		</dependency>
		<dependency>
			<groupId>junit</groupId>
			<artifactId>junit</artifactId>
		</dependency>
	</dependencies>
           

2.Service

package com.knife.testaop;

import org.springframework.stereotype.Component;

@Component
public class TestService {
	
	public String test(String message){
		return "TestService->test : "+message;
	}
	
}
           

3.aop攔截

package com.knife.testaop;

import org.apache.log4j.Logger;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.stereotype.Component;


@Component
@Aspect
public class TestAop {
	
	private Logger log = Logger.getLogger(getClass());

	
	@Around("execution(* com.knife.testaop.TestService.*(..))")
	public Object doAroundAdvice(ProceedingJoinPoint proceedingJoinPoint) {
		
		log.info("#################aop:" + proceedingJoinPoint.getSignature().getName());
		
        //擷取傳入參數的值
		String param="";
		Object[] args = proceedingJoinPoint.getArgs();
		if(args.length>0){
			param=(String)args[0];
			log.info("###############origin param:"+param);
		}
		
        //修改傳回參數的值
		try {
			return ((String)proceedingJoinPoint.proceed()).replace(param, "changed");
		} catch (Throwable e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
			return null;
		}
	}
	
}
           

4.測試

package com.knife.testaop;

import org.apache.log4j.Logger;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.test.context.web.WebAppConfiguration;

@RunWith(SpringJUnit4ClassRunner.class)
@SpringBootTest(classes = App.class)//這裡的App是springboot的啟動類名
@WebAppConfiguration
public class UnitTest {
	
	private Logger log = Logger.getLogger(getClass());

	@Autowired
	TestService testService;
	
	@Test
	public void test(){
		log.info(testService.test("testaop"));
	}
}
           

5.結果

2019-02-20 10:56:31.018  INFO 11796 --- [           main] com.knife.testaop.TestAop                : #################aop:test
2019-02-20 10:56:31.018  INFO 11796 --- [           main] com.knife.testaop.TestAop                : ###############origin param:testaop
2019-02-20 10:56:31.028  INFO 11796 --- [           main] com.knife.testaop.UnitTest               : TestService->test : changed