Аспектно-ориентированное программирование весной - PullRequest
2 голосов
/ 28 февраля 2012

28 февраля 2012 г. 12:46:54 вечера org.springframework.context.support.AbstractApplicationContext prepareRefresh INFO: Обновление org.springframework.context.support.ClassPathXmlApplicationContext@780024: дата запуска [вторник, 28 февраля 12:46:54 GMT+05: 30 2012];корень иерархии контекста 28 февраля 2012 г. 12:46:54 org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions ИНФОРМАЦИЯ: Загрузка определений компонентов XML из ресурса пути к классу [newSpringXMLConfig.xml] 28 февраля 2012 г. 12:46:55PM org.springframework., форма, LAspect];корень фабричной иерархии 28 февраля 2012 г. 12:46:55 org.springframework.beans.factory.support.DefaultSingletonBeanRegistry destroySingletons ИНФОРМАЦИЯ: Уничтожение синглетонов в org.springframework.beans.factory.support.DefaultListableBeanFactining@ beans98ac: def.springframework.aop.config.internalAutoProxyCreator, три, CIR, форма, LAspect];корень фабричной иерархии Исключение в потоке «main» org.springframework.beans.factory.BeanCreationException: Ошибка создания компонента с именем «tri», определенным в ресурсе пути к классу [newSpringXMLConfig.xml]: Ошибка инициализации компонента;Вложенное исключение - java.lang.IllegalArgumentException: Pointcut не правильно сформирован: ожидание «шаблона имени» в позиции символа 4 get () ^

at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:527)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:456)
at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:293)
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)
at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:290)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:192)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:585)
at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:895)
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:425)
at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:139)
at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:83)
at sam.mainaop.main(mainaop.java:16)

Причина: java.lang.IllegalArgumentException: Pointcut не являетсяправильно сформированный: ожидание «шаблона имени» в позиции символа 4 get () ^

at org.aspectj.weaver.tools.PointcutParser.resolvePointcutExpression(PointcutParser.java:316)
at org.aspectj.weaver.tools.PointcutParser.parsePointcutExpression(PointcutParser.java:294)
at org.springframework.aop.aspectj.AspectJExpressionPointcut.buildPointcutExpression(AspectJExpressionPointcut.java:195)
at org.springframework.aop.aspectj.AspectJExpressionPointcut.checkReadyToMatch(AspectJExpressionPointcut.java:181)
at org.springframework.aop.aspectj.AspectJExpressionPointcut.getClassFilter(AspectJExpressionPointcut.java:162)
at org.springframework.aop.support.AopUtils.canApply(AopUtils.java:200)
at org.springframework.aop.support.AopUtils.canApply(AopUtils.java:254)
at org.springframework.aop.support.AopUtils.findAdvisorsThatCanApply(AopUtils.java:286)
at org.springframework.aop.framework.autoproxy.AbstractAdvisorAutoProxyCreator.findAdvisorsThatCanApply(AbstractAdvisorAutoProxyCreator.java:117)
at org.springframework.aop.framework.autoproxy.AbstractAdvisorAutoProxyCreator.findEligibleAdvisors(AbstractAdvisorAutoProxyCreator.java:87)
at org.springframework.aop.framework.autoproxy.AbstractAdvisorAutoProxyCreator.getAdvicesAndAdvisorsForBean(AbstractAdvisorAutoProxyCreator.java:68)
at org.springframework.aop.framework.autoproxy.AbstractAutoProxyCreator.wrapIfNecessary(AbstractAutoProxyCreator.java:359)
at org.springframework.aop.framework.autoproxy.AbstractAutoProxyCreator.postProcessAfterInitialization(AbstractAutoProxyCreator.java:322)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyBeanPostProcessorsAfterInitialization(AbstractAutowireCapableBeanFactory.java:407)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1426)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:519)
... 11 more

Java Результат: 1 BUILD SUCCESSFUL (общее время: 1 секунда)

и код:

package sam; 

import org.aspectj.lang.annotation.Aspect; 
import org.aspectj.lang.annotation.Before; 
import org.aspectj.lang.annotation.Pointcut; 

@Aspect public class LoggingAspect { 
  @Before("get()") 
  public void LoggingAdvice() { 
    System.out.println("Good Afternoon"); 
  } 

  @Before("get()") 
  public void LAdvice() { 
    System.out.println("Good Morning"); 
  } 

  @Pointcut("execution(* get*())") 
  public void get() { } 
}

1 Ответ

1 голос
/ 28 февраля 2012

в соответствии с spring aop doc

Полный язык точек резки AspectJ поддерживает дополнительные указатели точек, которые не поддерживаются в Spring.Это: вызов, получение, установка, предварительная инициализация, статическая инициализация, инициализация, обработчик, выполнение рекомендации, внутри кода, cflow, cflowbelow, if, @this и @withincode.

, поэтому я предполагаю, что вам следует избегать конфликта имен в Spring Aop

...