spring的aop切面拦截第三方jar的问题
@Pointcut("execution(public*org.hibernate..*.*(..))")我想通过上面的切面路径拦截hibernate的方法的执行,但是一...
@Pointcut("execution(public * org.hibernate..*.*(..) ) ")
我想通过上面的切面路径拦截hibernate的方法的执行,但是一直拦截不到,这样写有问题吗?
拦截自己写的类的方法可以,拦截上面的失效,请高手指点下 展开
我想通过上面的切面路径拦截hibernate的方法的执行,但是一直拦截不到,这样写有问题吗?
拦截自己写的类的方法可以,拦截上面的失效,请高手指点下 展开
1个回答
展开全部
拦不到很正常,你这么写拦截的是hibernate自己的方法,但是实际上你用的是hibernate代理对象(proxy),所以实际上已经不是org.hibernate....之类的了,你应该拦截的是JavassistLazyInitializer.getProxy之后,使用proxy对象进行的数据库访问。
你打出debug级别的日志寻找一下吧。
你打出debug级别的日志寻找一下吧。
追问
我日志打出来,不是代理类啊getSession().getClass().getName()=org.hibernate.internal.SessionImpl
追答
不是这么打日志,是log4j自动的日志。
或者,你故意执行一条错误语句(比如insert到一张表里主键相同的数据),就可以看到console里有详细信息了,然后找一下proxy
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询