SPringAOP的使用
技术概述,描述这个技术是做什么?学习该技术的原因,技术的难点在哪里。
为了实现项目管理员端的操作数据库日志,便于方便所以利用Spring框架的AOP机制进行实现,项目的难点在于如果设置切入点,如何获取参数。
技术详述,描述你是如何实现和使用该技术的,要求配合代码和流程图详细描述。可以再细分多个点,分开描述各个部分。
在applicationContext.html" target="_blank">xml中开启AOP代理
<aop:aspectj-autoproxy />
自定义一个注解
@Target(ElementType.METHOD) @Retention(RetentionPolicy.RUNTIME) public @interface LogAnno { String operatorType(); }
编写一个切面类
@Component @Aspect public class LogAopAspect { @Autowired LogtableService logtableService;//Logtable为数据库中的一张表,用于存储日志信息 @Around("@annotation(qj.admin.aspect.LogAnno)")//设定需要捕获的标签 public Object around(ProceedingJoinPoint pjp) throws Throwable { MethodSignature methodSignature =(MethodSignature)pjp.getSignature(); Method method = methodSignature.getMethod(); String targetName = pjp.getTarget().getClass().getName(); System.out.println("增强的类是:"+targetName); System.out.println("增强的方法是:"+method.getName()); Method realMethod = pjp.getTarget().getClass().getDeclaredMethod(methodSignature.getName(), method.getParameterTypes()); LogAnno logAnno = realMethod.getAnnotation(LogAnno.class);//获取注解的方法上的自定义标签类 String operatortype = logAnno.operatorType();//获取到自定义标签上的注解如“修改账户状态” //String operatortype = "修改用户积分"; AdminLog adminLog = new AdminLog(); adminLog.setOperatortype(operatortype); adminLog.setOperator("123"); Object resultObject = null; Object [] parameter = pjp.getArgs();//获取注解的方法的传入参数 try { resultObject = pjp.proceed(); adminLog.setOperatorresult("正常 "+Arrays.toString(parameter)); } catch (Exception e) { // TODO: handle exception adminLog.setOperatorresult("失败"); } finally { adminLog.setOperatordate(new Date()); logtableService.addLog(adminLog); } return resultObject; }
用自定义注解注解一个方法
@LogAnno(operatorType = "修改账户状态") public void handleUser(int IDNumber, int type) { User user = userDAO.get(IDNumber); userDAO.update(user, type); }
项目目录结构
技术使用中遇到的问题和解决过程。要求问题的描述和解决有一定的内容,不能草草概括。要让遇到相关问题的人看了你的博客之后能够解决该问题。
刚刚开始的时候时候仅仅利用Method method = methodSignature.getMethod();来获取当前增强的方法,但是在接下来的LogAnno logAnno = method.getAnnotation(LogAnno.class);中get到的logAnno类为空,而上面通过打印System.out.println("增强的方法是:"+method.getName());显示增加的方法并没有错误,导致这就陷入了我的知识盲区,经过查找资料,大部分教程都说在自定义注解类中添加@Retention(RetentionPolicy.RUNTIME)即可解决问题,但是我添加之后还是同样的问题,最后意识到,可能这方法所获取的函数是两个不同的函数,最后又经过查找最终发现原来是这个aop拦截的是ServiceImpl的一个方法,然后这个ServiceImpl又启动了事务管理,而事务管理又是基于AOP的。
也就是说,这个权限的@Around的切面拦截的是个代理对象的方法,而代理对象的方法是不会把原来父类中的方法的注解加上去的,所以这里这个注解的对象为null。
最后运用Method realMethod = pjp.getTarget().getClass().getDeclaredMethod(methodSignature.getName(), method.getParameterTypes());获取到了真正需要的增强的函数。
总结
利用Spring的AOP机制确实能够大大减少代码量,很容易的就实现了日志的管理
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍Spring Aop之AspectJ注解配置实现日志管理的方法,包括了Spring Aop之AspectJ注解配置实现日志管理的方法的使用技巧和注意事项,需要的朋友参考一下 最近项目要做一个日志功能,我用Spring Aop的注解方式来实现。 创建日志注解 创建切面通知类 记录操作的方法名,参数和花费的时间,使用环绕通知 扫描和启动aop注解 日志注解的应用 效果 以上这篇Sprin
本文向大家介绍spring AOP自定义注解方式实现日志管理的实例讲解,包括了spring AOP自定义注解方式实现日志管理的实例讲解的使用技巧和注意事项,需要的朋友参考一下 今天继续实现AOP,到这里我个人认为是最灵活,可扩展的方式了,就拿日志管理来说,用Spring AOP 自定义注解形式实现日志管理。废话不多说,直接开始!!! 关于配置我还是的再说一遍。 在applicationContex
本文向大家介绍aop注解方式实现全局日志管理方法,包括了aop注解方式实现全局日志管理方法的使用技巧和注意事项,需要的朋友参考一下 1:日志实体类 2:maven需要的jar 这里要求项目使用的是jdk1.7 3:springServlet-mvc.xml 加上proxy-target-class="true"是为了可以拦截controller里面的方法 4:定义切面,我这里主要写前置通知和异常通
本文向大家介绍简单了解Java日志脱敏框架sensitive,包括了简单了解Java日志脱敏框架sensitive的使用技巧和注意事项,需要的朋友参考一下 这篇文章主要介绍了简单了解Java日志脱敏框架sensitive,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 问题 为了保证用户的信息安全,敏感信息需要脱敏。 项目开发过程中,每次处理敏感信
本文向大家介绍Spring AspectJ AOP框架注解原理解析,包括了Spring AspectJ AOP框架注解原理解析的使用技巧和注意事项,需要的朋友参考一下 什么是AspectJ AspectJ是一个面向切面的框架,它扩展了Java语言。AspectJ定义了AOP语法所以它有一个专门的编译器用来生成遵守Java字节编码规范的Class文件。 AspectJ是一个基于Java语言的AOP框
主要内容:1. 开启注解事务,2. 使用 @Transactional 注解,示例 1在《 Spring基于XML实现事务管理》一节中,我们通过 <tx:advice> 元素极大的简化了 Spring 声明式事务所需的 XML 配置。但其实我们还可以通过另一种方式进行进一步的简化,那就是“使用注解实现事务管理”。 在 Spring 中,声明式事务除了可以使用 XML 实现外,还可以使用注解实现,以进一步降低代码之间的耦合度。下面我们就来介绍下,通过注解是如何实现声明式事务管理。 1