目标:生成一个userdao的代理,然后在代理执行的过程中,把关于日志记录的逻辑加进去。
userdao.java:
userdaoimpl.java:
现在需要要在执行userdaoimpl的save方法之前和之后执行logintercept类的beforemethod与aftermethod方法赖创建日志。
首先让logintercept类实现动态代理的接口invocationhandler
然后重写invoke方法。
测试方法:
测试结果:
save start...
add success!!
save end...
当你有一件事情,需要在多个方法上面都要加相同的业务逻辑的时候,用动态代理会帮你省好多事情。
剖析一下动态代理的实现:
得到的是userdao接口吗?测试一下:
system.out.println(userdaoproxy.getclass());
得到:class $proxy4
说明userdaoproxy并不是userdao接口,而是jdk的一个动态代理类$proxy4,它是根据你传给它的参数中的接口那一项,得到接口本身,继而拿到接口的所有方法,哪个方法调用都会把接口本身传给invocationhandlder(li的invoke方法拿到)。
好了,我们写完了动态代理的aop,但是,到底什么是aop(aspect-oriented-programming)面向切面编程呢?
你会发现,我们正常的程序写起来就是一条直线,比如:
接受用户名密码--->连接数据库--->创建xxx对象--->存储--->创建日志--->end
而面向切面编程就好像我们在中间"咔嚓"砍掉一刀,在上面加上逻辑,在另外一个地方"咔嚓"一刀,也在上面加逻辑,而方法自己本身并不知道。
面向切面编程是面向对象编程的有一伟大思想。应用的地方太多,权限、日志、检查、事务(可以在crud方法前加上transiention.start(),事务结束后加上transiention.commit())、异常的管理(单独写一个业务逻辑,想给哪个方法加异常管理就加)。
比如权限,再给每个jsp文件设权限的时候,在每个jsp文件开始的时候要做个检查,正常的写jsp文件或方法,我们的业务逻辑才是我们的主要内容,但是由于要检查权限,非要在前面加上检查权限的代码,代码会很繁琐,不会专注于特定的内容了,而且去掉它的时候会很麻烦。
但是利用面向切面的编程,就不会产生这些问题,而且这些加上的业务逻辑可以利用spring的配置文件轻松的去掉或者加上。
现在是实现了invocationhandler,如果利用spring,不用实现invocationhandler{接口也可以,它就是使用了直接生成二进制码,用继承。
sturts2中的拦截器使用的就是aop切面编程
顺便说一下,一般写程序推荐面向接口编程。
转载请注明出处:http://blog.csdn.net/acmman/article/details/44276427