loggingbeforeaspect.java

来自「随书光盘:精通Sping 2.0 的随书源代码」· Java 代码 · 共 38 行

JAVA
38
字号
package test.aspect;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;

/**
 * 
 * @author worldheart
 *
 */
@Aspect
public class LoggingBeforeAspect {
	
	private static final Log log = LogFactory.getLog(LoggingBeforeAspect.class);
	
	//将连接点作用范围圈定在service包中
	@Pointcut("within(*test.service.*)")
	public void with(){}

	//连接点对应的方法的返回值必须是void或java.lang.String
	@Pointcut("execution(public void || String test.service..*(..))")
	public void service(){}
	
	//进行与运算
	@Before("service() && with() && args(str) && target(obj) && this(proxy) ")
	public void beforeAspect(JoinPoint jp, String str, Object obj, Object proxy){
		log.info(jp);
		log.info(str);
		log.info(obj);
		log.info(proxy);
	}
	
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?