ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

aop注解简单日志

2020-12-14 20:52:15  阅读:118  来源: 互联网

标签:String rs import org aop 注解 日志 null append


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) + "}"; 
    } 
}

标签:String,rs,import,org,aop,注解,日志,null,append
来源: https://blog.51cto.com/10983206/2564146

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有