spring aop实现日志功能

关键字 :sping aop实现日志功能


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

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

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


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


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;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值