在实际的项目中,特别是管理系统中,对于那些重要的操作我们通常都会记录操作日志。比如对数据库的操作,我们都会对每一次重要的操作进行记录,通常的做法是向数据库指定的日志表中插入一条记录。这里就产生了一个问题,难道要我们每次在 的时候都手动的插入日志记录吗?这肯定是不合适的,这样的操作无疑是加大了开发量,而且不易维护,所以实际项目中总是利用即面向切面编程这一技术来记录系统中的操作日志。
这里我把日志按照面向的对象不同分为两类:
- 面向用户的日志:用户是指使用系统的人,这一类日志通常记录在数据库里边,并且通常是记录对数据库的一些操作。
- 面向开发者的日志:查看这一类日志的一般都是开发人员,这类日志通常保存在文件或者在控制台打印(开发的时候在控制台,项目上线之后之后保存在文件中),这一类日志主要用于开发者开发时期和后期维护时期定位错误。
面向不同对象的日志,我们采用不同的策略去记录。很容易看出,对于面向用户的日志具有很强的灵活性,需要开发者控制用户的哪些操作需要向数据库记录日志,所以这一类保存在数据库的日志我们在使用 记录时用自定义注解的方式去匹配;而面向开发者的日志我们则使用表达式去匹配就可以了(这里有可能叙述的有点模糊,看了下面去案例将会很清晰),下面分别介绍两种日志的实现。
接下来分步骤介绍中怎样实现通过记录操作日志。
在文件中添加如下依赖:
在项目的文件中添加下面一句配置:

这里特别说明下,这句话不加其实也可以,因为默认就是,只要我们在中添加了依赖就可以了,这里提出来是让大家知道有这个有这个配置。
上边介绍过了了,因为这类日志比较灵活,所以我们需要自定义一个注解,使用的时候在需要记录日志的方法上添加这个注解就可以了,首先在启动类的同级包下边新建一个包,在这个报下边新建一个名为的文件,文件内容如下:

既然是向数据库中插入记录,那么前提是需要创建一张记录日志的表,下面给出我的表,由于是写样例,我这里这张表设计的很简单,大家可以自行设计。

当然还需要创建接口文件以及接口实现类,这里直接给出代码:
ISysLogServcie.java

SysLogServiceImpl.java


准备上边的相关文件后,下面来介绍重点–创建切面实现类,同样我们这里将该类放在包下,命名为,内容如下:





这里简单介绍下关于的几个重要注解:
- :这个注解表示将当前类视为一个切面类
- :表示将当前类交由管理。
- :切点表达式,定义我们的匹配规则,上边我们使用表示匹配带有我们自定义注解的方法。
- :环绕通知,可以在目标方法执行前后执行一些操作,以及目标方法抛出异常时执行的操作。
- 下面看一段关键的代码:

其中这句话表示执行目标方法,可以看出我们在这段代码执行之前打印了一句日志,并在执行之后调用了插入日志的方法,并且在方法中我们可以拿到目标方法所在的类名,方法名,参数等重要的信息。
在包下新建一个(名字大家随意),内容如下:


定义一个测试方法,带有两个参数,并且为该方法添加了我们自定义的注解,启动项目,浏览器访问,这时候查看控制台的部分输出信息如下:

首先这里我列举一个使用该方式的应用场景,在项目中出现了,我们想要知道前台的请求是否进入了我们控制器中,以及参数的获取情况,下面开始介绍实现步骤。
其实原理跟上边是一样的,只是切点的匹配规则变了而已,而且不用将日志记录到数据库,打印出来即可。
首先在中定义一个新的切点表达式,如下:

表示匹配包及其子包下的所有公有方法。
再添加匹配到方法时我们要做的操作:

:表示目标方法执行之前执行以下方法体的内容。
再在控制器中添加一个测试方法:

可以看到这个方法我们并没有加上注解,重启项目,浏览器访问localhost:8080/testaop3?name=xfr&nick=eran,这时候查看eclipse控制台的部分输出信息如下:

打印出了关键日志,这样我们就能知道是不是进入了该方法,参数获取是否正确等关键信息。
这里有的朋友或许会有疑问这样会不会与添加了的方法重复了呢,的确会,所以在项目中我通常都将注解用在了层的方法上,这样也更加合理。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/141144.html