📄 loggingintroductionaspect.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 + -