⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 loggingintroductionaspect.java

📁 随书光盘:精通Sping 2.0 的随书源代码
💻 JAVA
字号:
package test.aspect;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.DeclareParents;
import org.aspectj.lang.annotation.Pointcut;

import test.IIntroductionInfo;

/**
 * 
 * @author worldheart
 *
 */
@Aspect
public class LoggingIntroductionAspect {
	
	private static final Log log = LogFactory.getLog(LoggingIntroductionAspect.class);
	
	@DeclareParents(value="test.service.*",defaultImpl=test.IntroductionInfoImpl.class)
	public IIntroductionInfo iInfo;
	
	//传入str参数到@Around装备中
	@Pointcut("execution(public * test.service..*(..)) && args(str)")
	public void service(String str){}	
	
	@Around("service(str)" +
			" && target(obj) && this(proxy) ")
	public Object aroundAspect(ProceedingJoinPoint pjp, String str, Object obj, Object proxy){
		log.info(pjp);
		log.info(str);
		log.info(obj);
		log.info(proxy);
		try {
			str = "worldheart changed!";
			return pjp.proceed(new Object[]{str});
		} catch (Throwable e) {
			log.error(e);
		}
		return null;
	}
	
}

⌨️ 快捷键说明

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