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后端技术全栈