`
zhaoshijie
  • 浏览: 2243613 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

spring aop实现日志功能

阅读更多
关键字 :sping  aop实现日志功能


附件是sping  aop实现日志功能的完整的工程例子,

但是目前存在一个问题没有解决,就是直接用下面的方式加载配置文件可以拦截目标方法:

ClassPathXmlApplicationContext beanApp = new ClassPathXmlApplicationContext(
                "applicationContext.xml");



但是 作为web工程 在web.xml中加载   启动tomcat并且访问的时候拦截不到目标方法该问题已经解决 ......


spring AOP相关知识请看完:

Spring AOP部分使用JDK动态代理或者CGLIB来为目标对象创建代理。(建议尽量使用JDK的动态代理)

如果被代理的目标对象实现了至少一个接口,则会使用JDK动态代理。所有该目标类型实现的接口都将被代理。若该目标对象没有实现任何接口,则创建一个CGLIB代理。

如果你希望强制使用CGLIB代理,(例如:希望代理目标对象的所有方法,而不只是实现自接口的方法)那也可以。但是需要考虑以下问题:

无法通知(advise)Final 方法,因为他们不能被覆写。

你需要将CGLIB 2二进制发行包放在classpath下面,与之相较JDK本身就提供了动态代理

强制使用CGLIB代理需要将 <aop:config> 的 proxy-target-class 属性设为true:

<aop:config proxy-target-class="true">

...

</aop:config>
当需要使用CGLIB代理和@AspectJ自动代理支持,请按照如下的方式设置 <aop:aspectj-autoproxy> 的 proxy-target-class 属性:

<aop:aspectj-autoproxy proxy-target-class="true"/>











附件是完整的例子,可以直接测试运行Main.java

项目中使用时直接拷贝其中的LogIntercept类(该类直接是注解注解方式),只需要修改该类中的@Pointcut("execution(public * com.creatar.portal.service..*.*(..))")  包名称为你真实需要代理的包名即可,注意spring配置文件中一定要加上<aop:aspectj-autoproxy/>这句话  或强制代理类而不会接口加上<aop:aspectj-autoproxy proxy-target-class="true"/> 这句话



附件中的testWeblogic2项目是一个web项目,部署后直接打开http://localhost:8080/testWeblogic2/main.jsp然后点击   增加用户 提交后即可测试AOP代理日志功能(testWeblogic2还没有上传 在家中 ...)







关于代理类中获取request对象:

1、struts2 控制器:
@SuppressWarnings("unused")
private HttpServletRequest getStrutsRequest(){
    HttpServletRequest request = ServletActionContext.getRequest();
    return request;
     }
    
1、spring 控制器:
     @SuppressWarnings("unused")
private HttpServletRequest getSpringRequest(){
    HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
    return request;
     }
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics