Anulación de marco de resorte ¿La configuración basada en anotaciones con configuración basada en XML? Necesito cambiar una dependencia de un bean que ya está definida a través de anotaciones y no soy el autor del bean.¿Puede anular el marco de resorte? ¿Configuración basada en anotaciones con configuración basada en XML?
18
A
Respuesta
14
Esto debería estar bien. Un contexto de Spring Bean le permite redefinir beans, con definiciones "posteriores" que reemplazan a las "anteriores". Esto debería aplicarse a los beans definidos por XML, así como a los beans definidos por anotaciones, incluso si están mezclados.
Por ejemplo, si usted tiene
@Configuration
public class MyAnnotatedConfig {
@Bean
public Object beanA() {
...
}
}
<bean class="com.xyz.MyAnnotatedConfig"/>
<bean id="beanA" class="com.xyz.BeanA"/>
En este caso, la definición XML de beanA
debe prevalecer.
16
no sabía que la primavera puede mezclar configuraciones. aquí está el ejemplo detallado y muy útil.
Bean1 es el bean real que estamos configurando.
package spring;
import javax.annotation.PostConstruct;
import javax.annotation.PreDestroy;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Component;
@Component
public class Bean1 {
private String naber;
@Autowired
@Qualifier("FireImpl1")
private Fire fire;
@PostConstruct
public void init() {
System.out.println("init");
getFire().fire();
}
@PreDestroy
public void destroy() {
System.out.println("destroy");
}
public void setNaber(String naber) {
this.naber = naber;
}
public String getNaber() {
return naber;
}
public void setFire(Fire fire) {
this.fire = fire;
}
public Fire getFire() {
return fire;
}
}
fuego es interfaz dependencia
package spring;
public interface Fire {
public void fire();
}
y aplicación maniquí 1
package spring;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Component;
@Component
@Qualifier("FireImpl1")
public class FireImpl1 implements Fire {
public void fire() {
System.out.println(getClass());
}
}
y aplicación maniquí 2
package spring;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Component;
@Component
@Qualifier("FireImpl2")
public class FireImpl2 implements Fire {
public void fire() {
System.out.println(getClass());
}
}
config.xml
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:p="http://www.springframework.org/schema/p" xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:context="http://www.springframework.org/schema/context" xmlns:jee="http://www.springframework.org/schema/jee"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd
http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-2.5.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd">
<context:component-scan base-package="spring" />
<bean id="bean1" class="spring.Bean1">
<property name="naber" value="nice" />
<property name="fire" ref="fireImpl2" />
</bean>
</beans>
y clase principal
package spring;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class Spring {
public static void main(String[] args) {
ClassPathXmlApplicationContext applicationContext = new ClassPathXmlApplicationContext("/spring/config.xml");
applicationContext.registerShutdownHook();
Bean1 bean = (Bean1) applicationContext.getBean("bean1");
System.out.println(bean.getNaber());
}
}
aquí es la salida
init
class spring.FireImpl2
nice
destroy
Aunque anotación resuelve la dependencia a FireImpl1, config XML overrided con FireImpl2. muy agradable.
Cuestiones relacionadas
- 1. Jerarquía de configuración basada en anotaciones
- 2. Configuración Xml versus configuración basada en la anotación
- 3. Configuración de seguridad de primavera basada en código
- 4. ¿Por qué no puedo tener el mismo nombre de Controlador en un paquete diferente con configuración basada en anotaciones?
- 5. Creación de beans de primavera inicializados de forma diferida utilizando la configuración basada en anotaciones
- 6. ¿Podemos anular los granos de primavera declarados en una configuración xml en otra configuración?
- 7. Configuración de Lighttpd condicional basada en encabezados de solicitud
- 8. CakePHP - configuración de base de datos basada en la URL
- 9. Prueba de Resorte con configuración H2 db
- 10. de primavera: la inyección de constructor de valores primitivos (propiedades) con configuración basada en anotación
- 11. Configuración de resorte de C3P0 con Hibernate?
- 12. ¿Cómo se configura MappingJacksonHttpMessageConverter utilizando la configuración basada en la anotación de primavera?
- 13. serialización basada en el campo de Jackson
- 14. .Net Serialización XML basada en un XSD?
- 15. Anular configuración de Magento
- 16. Aplicación basada en el complemento en C#
- 17. cómo comenzar con el marco de resorte
- 18. Anular o desactivar el menú de configuración
- 19. Spring 3, con configuración basada en Java, y acceso de recursos problema
- 20. Configuración de log4net con el archivo xml
- 21. Generar configuración XML completa del muelle 3 anotaciones
- 22. JACKSON Asignación de la configuración XML Sin anotaciones
- 23. Condición basada en el valor del atributo (esquema XML)
- 24. ¡Variables de configuración en Play! Marco
- 25. Arquitectura basada en el espacio?
- 26. ¿Herramienta de compilación basada en JSON?
- 27. ¿Se puede anular la configuración ValidateRequest de una página?
- 28. Consola JMX basada en Web para Tomcat?
- 29. ¿Hay alguna manera de obtener una instancia de System.Configuration.Configuration basada en xml arbitrario?
- 30. Buenos patrones para pruebas unitarias de beans que tienen validación basada en anotaciones en Spring MVC
Sin embargo, esto podría no funcionar para los campos '@ Autowired', según el tipo? Esto parece lanzar 'org.springframework.beans.factory.NoSuchBeanDefinitionException: no se define ningún bean único de tipo [com.xyz.BeanA]: bean de coincidencia única esperado, pero se encontró 2: [beanA, beanA]' (Spring 3.2) – Arjan