马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有账号?立即注册
x
日志存入数据库(AOP)
1.引入aop依靠
- <!-- aop依赖 -->
- <dependency>
- <groupId>org.springframework.boot</groupId>
- <artifactId>spring-boot-starter-aop</artifactId>
- </dependency>
复制代码 2.创建自界说注解类(用于在Controller层使用注解标注哪个方法需要增加日志)
- 在log包下创建Log.java文件
- @Target(ElementType.METHOD)
- @Retention(RetentionPolicy.RUNTIME)
- public @interface Log {
- String value() default "";
- }
- @interface 注解类,自定义注解
- @Target 用来说明该注解可以被声明在那些元素之前
- ElementType.METHOD说明该注解只能被声明在一个类的方法前
- @Retention 用来说明该注解类的生命周期。
- RetentionPolicy.RUNTIME注解保留在程序运行期间,此时可以通过反射获得定义在某个类上的所有注解
复制代码 3.编写LogAspect增强类与增强方法(我们使用环绕增强around)
- @Aspect
- @Component
- public class LogAspect {
- //切入点,指定当使用Log注解时进入环绕增强
- @Pointcut("@annotation(com.hz.log.Log)")
- public void pointcut() {}
- @Around("pointcut()")
- public Object around(ProceedingJoinPoint point) {
- try {
- System.out.println("执行环绕增强..............开始");
- Object result = point.proceed();//执行方法
- System.out.println("结束..........");
- return result;
- } catch (Throwable throwable) {
- throwable.printStackTrace();
- }
- return null;
- }
- }
复制代码 4.创建controller进行测试
- @Log("获取所有用户集合")
- @GetMapping("/getSfUserList")
- public List<SfUser> getSfUserList() {
- List<SfUser> sfUserList = sfUserService.getSfUserList(1);
- System.out.println(sfUserList.size());
- return sfUserList;
- }
复制代码 5.开始写入数据库
- DROP TABLE IF EXISTS `sys_log`;
- CREATE TABLE `sys_log` (
- `ID` bigint(20) NOT NULL AUTO_INCREMENT,
- `USERNAME` varchar(50) DEFAULT NULL COMMENT '用户名',
- `OPERATION` varchar(50) DEFAULT NULL COMMENT '用户操作',
- `TIME` int(11) DEFAULT NULL COMMENT '响应时间',
- `METHOD` varchar(200) DEFAULT NULL COMMENT '请求方法',
- `PARAMS` varchar(500) DEFAULT NULL COMMENT '请求参数',
- `IP` varchar(64) DEFAULT NULL COMMENT 'IP地址',
- `CREATE_TIME` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
- PRIMARY KEY (`ID`)
- ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
复制代码 6.创建实体类
- /**
- * 日志记录实体类
- */
- public class SysLog {
- private Long id;
- private String username;
- private String operation;
- private Integer time;
- private String method;
- private String params;
- private String ip;
- private Date createTime;
- .....get...set...
- }
复制代码 7.编写DAO层接口与实现,向表中插入数据
- @Repository
- public class SysLogDaoImpl implements SysLogDao {
- @Autowired
- @Qualifier("mysqlJdbcTemplateOne") //使用第一个数据源
- private JdbcTemplate jdbcTemplate;
- //保存信息到日志表
- @Override
- public void saveSysLog(SysLog syslog) {
- String sql = "insert into sys_log(USERNAME,OPERATION,TIME,METHOD,PARAMS,IP)";
- jdbcTemplate.update(sql,new Object[]
- {syslog.getUsername(),syslog.getOperation(),syslog.getTime(),syslog.getMethod(),
- syslog.getParams(),syslog.getIp()});
- }
- }
复制代码 8.修改LogAspect增强类与增强方法
- @Aspect
- @Component
- public class LogAspect {
- @Autowired
- private SysLogDao sysLogDao;
- @Pointcut("@annotation(com.hz.log.Log)")
- public void pointcut() {}
- @Around("pointcut()")
- public Object around(ProceedingJoinPoint point) {
- try {
- long beginTime = System.currentTimeMillis();//开始执行时间
- Object result = point.proceed();//执行方法
- // 执行时长(毫秒)
- long time = System.currentTimeMillis() - beginTime;
- //实例化日志类
- SysLog sysLog = new SysLog();
- sysLog.setUsername("wzy");//模拟一个用户名 实际可以从session中获取
- sysLog.setTime((int) time);//执行时长(毫秒)
- // 获取request
- HttpServletRequest request =
- HttpContextUtils.getHttpServletRequest();
- // 设置IP地址
- sysLog.setIp(IPUtils.getIpAddr(request));
- MethodSignature signature = (MethodSignature) point.getSignature();
- Method method = signature.getMethod();
- Log logAnnotation = method.getAnnotation(Log.class);
- if (logAnnotation != null) {
- // 注解上的描述
- sysLog.setOperation(logAnnotation.value());
- }
- // 请求的方法名
- String className = point.getTarget().getClass().getName();
- String methodName = signature.getName();
- sysLog.setMethod(className + "." + methodName + "()");
- // 请求的方法参数值
- Object[] args = point.getArgs();
- // 请求的方法参数名称
- LocalVariableTableParameterNameDiscoverer u = new
- LocalVariableTableParameterNameDiscoverer();
- String[] paramNames = u.getParameterNames(method);
- if (args != null && paramNames != null) {
- String params = "";
- for (int i = 0; i < args.length; i++) {
- params += " " + paramNames[i] + ": " + args[i];
- }
- sysLog.setParams(params);
- }
- // 保存系统日志
- sysLogDao.saveSysLog(sysLog);
- return result;
- } catch (Throwable throwable) {
- throwable.printStackTrace();
- }
- return null;
- }
- }
- 注意:
- IP的获取需要工具类,网上可以自行查找
- 获取参数与获取方法名的方式都可以从网站查询
复制代码 9.运行测试@Log
日志控制台打印与写入文件(logback)
1.创建logback-spring.xml文件放入resource下,并复制内容到该文件
2.配置application.properties文件
- #读取配置文件
- logging.config=classpath:logback-spring.xml
复制代码 3.编写controller测试
- Logger log = Logger.getLogger(SfUserController.class);
- log.info("要输出的内容");//输出信息
- 等级可分为OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL,如果配置OFF则不打出任何信息,如果配置
- 为INFO这样只显示INFO, WARN, ERROR的log信息,而DEBUG信息不会被显示
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |