aop注解简单日志
mport java.lang.reflect.Method;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
@Component
@Aspect
public class LogAspectForPaypal {
private final static Logger log = LoggerFactory.getLogger(LogAspectForPaypal.class);
/**
* 添加业务逻辑方法切入点
*/
@Pointcut("execution(* com.tian.service.**Service.*(..))")
public void methodPointcut() {
}
@Before(value = "methodPointcut()")
public void getInputParameters(JoinPoint joinPoint) {
// 判断参数
if (joinPoint.getArgs() == null) {
return;
}
// 获取方法名
String methodName = joinPoint.getSignature().getName();
// 获取操作内容
String opContent = optionContent(joinPoint.getArgs(), methodName);
if (log.isInfoEnabled()) {
log.info(opContent);
}
}
/**
* 使用Java反射来获取被拦截方法的参数值, 将参数值拼接为操作内容
*
* @param args
* @param mName
* @return
*/
public String optionContent(Object[] args, String mName) {
String result = null;
if (args == null) {
return null;
}
StringBuilder rs = new StringBuilder();
rs.append("methodName:");
rs.append(mName);
String className = null;
// 遍历参数对象
for (Object info : args) {
// 获取对象类型
className = info.getClass().getName();
className = className.substring(className.lastIndexOf(".") + 1);
rs.append(", parameters:{");
// 获取对象的所有方法
Method[] methods = info.getClass().getDeclaredMethods();
// 遍历方法,判断get方法
for (Method method : methods) {
String methodName = method.getName();
// 判断是不是get方法
if (methodName.indexOf("get") == -1) {// 不是get方法
continue;// 不处理
}
Object rsValue = null;
try {
// 调用get方法,获取返回值
rsValue = method.invoke(info);
} catch (Exception e) {
continue;
}
if (rsValue != null) {
// 将值加入内容中
rs.append("\"");
rs.append(methodName.substring(3));
rs.append("\":\"");
rs.append(rsValue);
rs.append("\",");
}
}
}
result = rs.toString();
return result.substring(0, result.length() - 1) + "}";
}
}
欢迎关注公众号:Java后端技术全栈