zoukankan      html  css  js  c++  java
  • 用AOP记录操作日志,并写进数据库。

    先用AOP注解  
    1
    package com.vlandc.oss.apigate.log.aspect; 2 3 import java.util.Map; 4 import java.util.Optional; 5 6 import javax.servlet.http.HttpServletRequest; 7 8 import org.aspectj.lang.JoinPoint; 9 import org.aspectj.lang.annotation.After; 10 import org.aspectj.lang.annotation.AfterReturning; 11 import org.aspectj.lang.annotation.AfterThrowing; 12 import org.aspectj.lang.annotation.Aspect; 13 import org.aspectj.lang.annotation.Before; 14 import org.aspectj.lang.annotation.Pointcut; 15 import org.slf4j.Logger; 16 import org.slf4j.LoggerFactory; 17 import org.springframework.beans.factory.annotation.Autowired; 18 import org.springframework.context.ApplicationContext; 19 import org.springframework.stereotype.Component; 20 import org.springframework.web.context.request.RequestContextHolder; 21 import org.springframework.web.context.request.ServletRequestAttributes; 22 23 import com.vlandc.oss.apigate.log.annotation.IUserLogAction; 24 import com.vlandc.oss.apigate.log.annotation.UserLogActionAnnotation; 25 import com.vlandc.oss.apigate.log.annotation.UserLogAnnotation; 26 import com.vlandc.oss.apigate.shiro.token.UserInfo; 27 import com.vlandc.oss.apigate.shiro.token.manager.TokenManager; 28 import com.vlandc.oss.common.JsonHelper; 29 30 @Aspect 31 @Component 32 public class UserLogAspect { 33 34 private final static Logger logger = LoggerFactory.getLogger(UserLogAspect.class); 35 36 ThreadLocal<UserLogBean> userLogObj = new ThreadLocal<>(); 37 38 @Autowired 39 private TokenManager tokenManager; 40 41 @Autowired 42 private UserLogManager userLogManager; 43 44 @Autowired 45 private ApplicationContext context; 46 47 @Pointcut("@annotation(com.vlandc.oss.apigate.log.annotation.UserLogAnnotation)" 48 + "|| @annotation(com.vlandc.oss.apigate.log.annotation.UserLogActionAnnotation)") 49 public void userLog() { 50 } 51 52 protected UserInfo getCurrentUserInfo(String token) { 53 UserInfo userInfo = tokenManager.getUserInfo(token); 54 if (null != userInfo) { 55 return userInfo; 56 } else { 57 return null; 58 } 59 } 60 61 @Before(value = "userLog() && !@annotation(com.vlandc.oss.apigate.log.annotation.UserLogAnnotation)") 62 public void doBefore(JoinPoint joinPoint) throws Throwable { 63 parseCommonUserLogBean(joinPoint); 64 } 65 66 @Before(value = "userLog() && @annotation(ul)", argNames = "joinPoint,ul") 67 public void doBefore(JoinPoint joinPoint, UserLogAnnotation ul) throws Throwable { 68 parseCommonUserLogBean(joinPoint); 69 70 Object[] args = joinPoint.getArgs(); 71 Optional.ofNullable(args).map(t -> { 72 try { 73 if (ul.loginIdOrder() > -1) { 74 userLogObj.get().setLoginId(String.valueOf(t[ul.loginIdOrder()])); 75 } 76 userLogObj.get().setTargetType(ul.targetType().name()); 77 userLogObj.get().setTarget(String.valueOf(t[ul.targetOrder()])); 78 } catch (Exception e) { 79 logger.error("parse user log target error :" + JsonHelper.toJson(userLogObj.get()) + "; target annotation:" + ul.targetOrder() + "-" + ul.targetType().name()); 80 } 81 return t; 82 }); 83 } 84 85 private void parseCommonUserLogBean(JoinPoint joinPoint) { 86 UserLogBean userLogBean = new UserLogBean(); 87 userLogObj.set(userLogBean); 88 userLogBean.setStartTime(System.currentTimeMillis() / 1000); 89 userLogBean.setAction(joinPoint.getSignature().getName()); 90 91 Object[] args = joinPoint.getArgs(); 92 Optional.ofNullable(args).map(t -> { 93 userLogBean.setParameter(JsonHelper.toJson(t)); 94 return t; 95 }); 96 97 ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes(); 98 HttpServletRequest httpRequest = attributes.getRequest(); 99 UserInfo userInfo = getCurrentUserInfo(httpRequest.getHeader(TokenManager.TOKEN_KEY)); 100 Optional.ofNullable(userInfo).map(t -> { 101 userLogBean.setLoginId(t.getLoginId()); 102 userLogBean.setUserName(t.getName()); 103 return t; 104 }); 105 } 106 107 @AfterReturning(returning = "result", pointcut = "userLog() && !@annotation(com.vlandc.oss.apigate.log.annotation.UserLogActionAnnotation)") 108 public void doAfterReturning(Object result) throws Throwable { 109 parseCommonResult(result); 110 } 111 112 @AfterReturning(returning = "result", pointcut = "userLog() && @annotation(ula)", argNames = "result,ula") 113 public void doAfterReturning(Object result, UserLogActionAnnotation ula) throws Throwable { 114 try { 115 userLogObj.get().setTargetType(ula.targetType().name()); 116 117 String userLogActionName = Optional.ofNullable(ula).map(t -> t.userLogAction()).orElse(""); 118 if (context.containsBean(userLogActionName)) { 119 IUserLogAction userLogAction = (IUserLogAction) context.getBean(userLogActionName); 120 if(ula.defaultTargetKey().length() > 0) { 121 userLogAction.parseUserLogResult(ula.defaultTargetKey(), result, userLogObj.get()); 122 }else { 123 userLogAction.parseUserLogResult(result, userLogObj.get()); 124 } 125 } 126 } catch (Exception e) { 127 logger.error("parse target user log result error!", e); 128 } 129 130 parseCommonResult(result); 131 } 132 133 private void parseCommonResult(Object result) { 134 if (result instanceof String) { 135 userLogObj.get().setResult((String) result); 136 137 } else if (result instanceof Map) { 138 userLogObj.get().setResult(JsonHelper.toJson(result)); 139 } 140 try { 141 logger.debug("the syslog object is " + JsonHelper.toJson(userLogObj.get())); 142 userLogManager.saveUserLog(userLogObj.get()); 143 } catch (Exception e) { 144 logger.error("set sys log result error!", e); 145 } 146 } 147 148 @AfterThrowing(throwing = "ex", pointcut = "userLog()") 149 public void throwss(JoinPoint jp, Exception ex) { 150 151 } 152 153 @After("userLog()") 154 public void after(JoinPoint jp) { 155 userLogObj.get().setEndTime(System.currentTimeMillis() / 1000); 156 } 157 }
    package com.vlandc.oss.apigate.log.aspect;
    
    import java.text.SimpleDateFormat;
    import java.util.Date;
    import java.util.HashMap;
    import org.slf4j.Logger;
    import org.slf4j.LoggerFactory;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.stereotype.Component;
    
    import com.vlandc.oss.apigate.db.DBService;
    import com.vlandc.oss.apigate.db.DBServiceConst;
    import com.vlandc.oss.apigate.log.annotation.OssUserLogRabbitMQClient;
    
    @Component
    public class UserLogManager {
        private final static Logger logger = LoggerFactory.getLogger(UserLogManager.class);
    
        public static final String USER_LOG_INDEX_PREFIX = "ossuserlog";
        public static final String USER_LOG_INDEX_TYPE = "log";
        
        public static String getCurrentlogIndex() {
            SimpleDateFormat sdf = new SimpleDateFormat("yyyy.MM.dd");
            return USER_LOG_INDEX_PREFIX + "-" + sdf.format(new Date());
        }
        
        @Autowired
        private OssUserLogRabbitMQClient ossUserLogMQClient;
        
        @Autowired
        private DBService dbService;
        
        public void saveUserLog(UserLogBean logContext){
            try {
                ossUserLogMQClient.send(logContext);
                insertUserLog(logContext);
            } catch (Exception e) {
                logger.error("send user log to rabbitmq and db !" , e);
            }
        }
       // 直接写入数据库
        private void insertUserLog(UserLogBean logContext) {
            HashMap<String, Object> parameters = new HashMap<String, Object>();
            parameters.put("loginId", logContext.getLoginId());
            parameters.put("response", logContext.getResult());
            parameters.put("user", logContext.getUserName());
            parameters.put("type", logContext.getTargetType());
            parameters.put("subType", logContext.getAction());
            parameters.put("ts", logContext.getStartTime());
            parameters.put("endTs", logContext.getEndTime());
            
            dbService.insert(DBServiceConst.INSERT_USER_LOG, parameters);
        }
    }
  • 相关阅读:
    mybatis date类型比较
    搭建 c 语言环境 1_centos6 minimal 配置 c/c++ 编译环境
    2_eclipse配置c/c++环境
    1_eclipse导入hibernate 的DTD 文件
    1_eclipse配置c/c++开发环境
    2_修改Eclipse里面的快捷键
    1_修改注释内容
    8_对象创建、static 关键字、静态变量和成员变量的区别、文档
    7_匿名对象、封装(private)、this 关键字、构造方法
    6_面向对象基础、成员变量和局部变量的区别
  • 原文地址:https://www.cnblogs.com/fenghh/p/10036758.html
Copyright © 2011-2022 走看看