TinyFrame再续篇:整合Spring AOP实现日志拦截
上一篇中主要讲解了如何使用Spring IOC实现依赖注入的。但是操作的时候,有个很明显的问题没有解决,就是日志记录问题。如果手动添加,上百个上千个操作,每个操作都要写一遍WriteLog方法,工作量的巨大是可想而知的,更别说还有用户验证这块了。所以说,解决这种问题的方法最好是进行类的横切,OK,让我们进入正题吧。
首先,在解决方案中新建一个名称为BookStore.AOP的类库项目,然后向其中添加IAdvice并继承自IMethodInterceptor接口和IDisposable接口。
然后定义三个方法:
void Initializement();
void BeforeCall(IMethodInvocation invocation);
void AfterCall(IMethodInvocation invocation);
具体代码如下:
1: using System;
2: using AopAlliance.Intercept;
3:
4: namespace BookStore.AOP
5: {
6: public interface IAdvice : IMethodInterceptor, IDisposable
7: {
8: void Initializement();
9: void BeforeCall(IMethodInvocation invocation);
10: void AfterCall(IMethodInvocation invocation);
11: }
12: }
其中Initializement方法主要提供初始化行文;BeforeCall方法主要是在函数执行前触发;AfterCall方法主要是在函数执行后触发。
建立好这个接口之后,新建一个LogAdvice类,继承自刚刚建立的IAdvice接口,并添加如下代码:
1: using System;
2:
3: namespace BookStore.AOP
4: {
5: /*
6: 请在需要消费AOP的地方添加对BookStore.AOP的引用,否则会出现错误。
7: */
8: public class LogAdvice:IAdvice
9: {
10: public LogAdvice()
11: {
12: Initializement();
13: }
14:
15: private log4net.ILog log;
16:
17: public void Initializement()
18: {
19: log4net.Config.XmlConfigurator.Configure();
20: log = log4net.LogManager.GetLogger(typeof(LogAdvice));
21: }
22:
23: public void BeforeCall(AopAlliance.Intercept.IMethodInvocation invocation)
24: {
25: log.Info(string.Format("调用函数开始:{0}", invocation.Method.Name));
26: }
27:
28: public void AfterCall(AopAlliance.Intercept.IMethodInvocation invocation)
29: {
30: log.Info(string.Format("调用函数结束:{0}", invocation.Method.Name));
31: }
32:
33: public object Invoke(AopAlliance.Intercept.IMethodInvocation invocation)
34: {
35: try
36: {
37: BeforeCall(invocation);
38: object resultObj = invocation.Proceed();
39: AfterCall(invocation);
40: return resultObj;
41: }
42: catch (Exception ex)
43: {
44: log.Error(string.Format("调用函数错误:{0},{1},{2}", invocation.Method.Name, ex.Message, ex.StackTrace));
45: return null;
46: }
47: }
48:
49: public void Dispose()
50: {
51:
52: }
53: }
54: }
由于这里的日志记录,我采用了Log4net来进行配置,所以不懂的同学,可以参考我之前的文章Log4Net使用方法小记来进行。
需要说明一点的是,在BeforeCall函数,AfterCall函数,Invoke函数中,我们得到的传入参数都是AopAlliance.Intercept.IMethodInvocation,通过这个参数,我们可以拦截用户当前请求的是什么函数,什么类型等等,非常方便。需要特别注意的是,在Invoke方法中,程序调用invocation.Proceed来拦截函数的执行,这也就是所谓的方法横切操作。
写到这里,我们的编码工作算是完成了,下面来开始配置AOP横切。
打开BookStore.RestService项目,双击Web.config配置文件,新添加如下的节点段落,名称分别为BookRepositoryAOP以及LogTraceAroundAdvice:
1: <!--Spring Config Node-->
2: <spring>
3: <context>
4: <resource uri="config://spring/objects"/>
5: </context>
6: <objects xmlns="http://www.springframework.net">
7: <!--without aop-->
8: <object name="BookRepository" type="BookStore.Data.BookRepository, BookStore.Data" />
9:
10: <!--with aop-->
11: <object name="BookRepositoryAOP" type="Spring.Aop.Framework.ProxyFactoryObject" >
12: <property name="Target">
13: <object type="BookStore.Data.BookRepository, BookStore.Data" />
14: </property>
15: <property name="InterceptorNames">
16: <list>
17: <value>LogTraceAroundAdvice</value>
18: </list>
19: </property>
20: </object>
21: <!--Advices-->
22: <object id="LogTraceAroundAdvice" type="BookStore.AOP.LogAdvice, BookStore.AOP"></object>
23: </objects>
24: </spring>
其中名称为BookRepositoryAOP的节点表明当前采用AOP方式进行,横切的目标是BookStore.Data.BookRepository;横切的处理是BookStore.AOP.LogAdvice。配置好后,一定不要忘记添加对BookStore.AOP项目的引用。
这之后,打开BookService类,修改构造初始化为刚刚配置的节点:
1: public BookService()
2: : base()
3: {
4: bookRepository = (IBookRepository)applicationContext["BookRepositoryAOP"];
5: }
然后执行,我们就可以看到拦截的日志消息了,如果执行的时候,出现错误,还能够将错误信息捕捉,是不是感觉有了AOP,腰不酸了,腿不痛了的感觉呢?

这节就到这里了,下节主要讲解用户验证这块,也是利用横切来进行。
这里允许我白话一下:接口这东西在小项目中根本用不到,但是在大项目中,是必不可少的。IOC,AOP全靠它了。并且模块与模块之间交互,利用接口来规范,大大降低了耦合度,真好啊。
TinyFrame再续篇:整合Spring AOP实现日志拦截的更多相关文章
- Spring AOP进行日志记录,管理
在java开发中日志的管理有很多种.我一般会使用过滤器,或者是Spring的拦截器进行日志的处理.如果是用过滤器比较简单,只要对所有的.do提交进行拦截,然后获取action的提交路径就可以获取对每个 ...
- Spring AOP统一日志 全量日志
Spring AOP 切面@Around注解的具体使用 lichuangcsdn 2019-02-19 23:21:36 63936 收藏 61分类专栏: Spring 文章标签: Spring AO ...
- Spring AOP 完成日志记录
Spring AOP 完成日志记录 http://hotstrong.iteye.com/blog/1330046
- Spring AOP进行日志记录
在java开发中日志的管理有很多种.我一般会使用过滤器,或者是Spring的拦截器进行日志的处理.如果是用过滤器比较简单,只要对所有的.do提交进行拦截,然后获取action的提交路径就可以获取对每个 ...
- TinyFrame尾篇:整合Spring AOP实现用户认证
创建Manager用户验证表 这一篇主要讲解使用AOP对用户操作进行验证,如果通过验证,则继续执行,反之,则不能执行.其思想和上一篇完全一致. 由于需要用到用户认证,所以我们新建一个Manager实体 ...
- spring aop实现日志收集
概述 使用spring aop 来实现日志的统一收集功能 详细 代码下载:http://www.demodashi.com/demo/10185.html 使用spring aop 来实现日志的统一收 ...
- 使用Spring AOP 实现日志管理(简单教程)
有时候,我们在做项目时会遇到这样的需求: 给XXX.java中的所有方法加上指定格式的日志输出. 针对这种指定类.或者指定方法进行共性操作的功能,我们完全可以使用Spring AOP来实现. 本文使用 ...
- Spring AOP原理及拦截器
原理 AOP(Aspect Oriented Programming),也就是面向方面编程的技术.AOP基于IoC基础,是对OOP的有益补充. AOP将应用系统分为两部分,核心业务逻辑(Core bu ...
- Spring AOP的日志记录
现在的项目是Spring+MyBatis,前段时间项目经理让我干了一个活,就是给所有的controller里的所有方法加上日志记录的代码,其实没有多少,也就300来个方法,也没有抱怨什么,一边打着瞌睡 ...
随机推荐
- 你知道C#中的Lambda表达式的演化过程吗
你知道C#中的Lambda表达式的演化过程吗? 阅读目录 委托的使用 匿名方法 Func和Action Lambda的诞生 那得从很久很久以前说起了,记得那个时候... 懵懂的记得从前有个叫委托的东西 ...
- Java虚拟机内存管理原理基础入门
Jdk:Java程序设计语言.Java虚拟机.Java API类库. Jdk是用于支持Java程序开发的最小环境. Jre:Java API类库中的Java SE API子集.Java虚拟机. Jre ...
- 在unix系统下的 .o文件 .a文件 .so文件说明和相互关系
.o文件 .o文件就是对象文件,包含编译好的可执行代码,当程序执行时,被链接库链接调用[相当于windows里的obj文件] .a文件unix中的静态链接库,包含多个需要包含的.o文件,主要特点是在 ...
- sqlplus: error while loading shared libraries: /u01/app/lib/libclntsh.so.11.1
成功安装了Oracle 11g后,使用sqlplus登录数据库时遇到下面错误: [oracle@DB-Server ~]$ sqlplus / as sysdba sqlplus: error w ...
- ORACLE SQL Developer日期显示格式设置
ORACLE的SQL Developer工具默认的日期格式DD-MON-RR,在SQL查询中往往你看不到时间信息,此时你必须修改日期格式.具体如下所示 工具->首选项->数据库->N ...
- 根据上一行填充本行的空白栏位,SQL处理方式
我在4年多前,写了一篇Excel处理空白Cell的文章,http://www.cnblogs.com/studyzy/archive/2010/04/07/1706203.html,其实在数据库中也会 ...
- Activiti之 Exclusive Gateway
一.Exclusive Gateway Exclusive Gateway(也称为XOR网关或更多技术基于数据的排他网关)经常用做决定流程的流转方向.当流程到达该网关的时候,所有的流出序列流到按照已定 ...
- 论Top与ROW_NUMBER读取第一页的效率问题
10.29 前一段时间研究关于分页的问题,由于数据库属于百万级的,考虑了关于优化方面的问题.其中一个考虑是:第一页展现的频率肯定是最高的,所以我想第一页就使用Top N来读取. 这个想法本身是没有错, ...
- 讲讲js中的逻辑与(&&)以及逻辑或(||)
前几天看到一个函数,百思不得其解,今天早上醒来看了本js的书,正好讲到操作符的用法,给大家分享下js中的&&,||,和我们用的其他的编程语言还是有点区别的. 直接上那个函数的代码: f ...
- WIN 下的超动态菜单(一)
WIN 下的超动态菜单(一)介绍 WIN 下的超动态菜单(二)用法 WIN 下的超动态菜单(三)代码 作者:黄山松,发表于博客园:http://www.cnblogs.com/tomview/ ...