Les projets Spring traditionnels auront de nombreux fichiers de configuration. Par exemple, si nous voulons utiliser Redis, généralement en plus des packages jar dépendants correspondants, nous devons également configurer JedisConnectionFactory, JedisPoolConfig et RedisTemplate dans l'application. XML. Mais si vous utilisez SpringBoot, le système générera automatiquement ces classes en fonction du package jar dans pom.xml et les injectera dans le conteneur IOC.
La configuration est requise dans les projets Spring traditionnels
<bean id="jedisConnectionFactory" class="...JedisConnectionFactory"></bean> <bean id="poolConfig" class="redis.clients.jedis.JedisPoolConfig"></bean> <bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate"></bean>
Mais lors de l'utilisation de SpringBoot, en plus d'introduire le package jar correspondant dans pom, obtenez plus de 120 classes de configuration de fonctions par défaut à partir de spring-boot-autoconfigure.jar/META-INF/spring. .factories, y compris le nom complet de la classe de configuration de fonction de Redis, RedisAutoConfiguration. Généralement, une classe de configuration de fonction entoure cette fonction et est responsable de la gestion de la création de plusieurs classes fonctionnelles associées, telles que RedisAutoConfiguration, qui est responsable de la création de trois classes fonctionnelles :
org.springframework.boot.autoconfigure.data.redis.RedisAutoConfiguration,\
@Configuration @ConditionalOnClass({ JedisConnection.class, RedisOperations.class, Jedis.class }) @EnableConfigurationProperties(RedisProperties.class) public class RedisAutoConfiguration {}
Si pom.xml a un package jar correspondant, il peut correspondre à la classe de dépendance correspondante : JedisConnection.class, RedisOperations.class, Jedis Uniquement lorsque class
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency>
correspond avec succès. , cette classe de configuration de fonction prendra effet et la classe de configuration de propriété par défaut @EnableConfigurationProperties(RedisProperties.class) sera injectée. Pour JedisConnectionFactory et RedisTemplate, la condition est qu'il n'y ait pas de
@ConfigurationProperties(prefix = "spring.redis") public class RedisProperties { private int database = 0; private String url; private String host = "localhost"; private String password; private int port = 6379;
Analyse des principes et des résultats
En résumé, afin d'assembler automatiquement une classe, deux conditions doivent être remplies :
Le résultat de l'ensemble du processus est deux choses :
annotations dépendantes
@SpringBootApplication : L'annotation de la classe de démarrage de l'application du projet sb est en fait une combinaison de 3 annotations : @SpringBootConfiguration, @EnableAutoConfiguration, @ComponentScan, dont le second joue un rôle dans l'assemblage automatique
@EnableAutoConfiguration : indique la fonction de l'application SB pour démarrer l'assemblage automatique (y compris le chargement des beans correspondants dans le conteneur IOC, et selon la configuration par défaut, attribue des valeurs aux attributs)
@Import(EnableAutoConfigurationImportSelector.class) : Cette annotation est assez puissante et peut enregistrer de force les beans qui ne sont pas enregistrés dans l'IOC, indiquant qu'ils doivent démarrer. la fonction de configuration automatique, EnableAutoConfigurationImportSelector.class doit être introduite
@ConditionalOnClass({ JedisConnection.class, RedisOperations.class, Jedis.class }) : indique que pour que la classe de configuration RedisAutoConfiguration fonctionne. , il doit y avoir un package jar contenant ces classes
@EnableConfigurationProperties(RedisProperties.class) : Indique que la configuration dans RedisProperties.class est référencée par défaut
@ConditionalOnMissingBean(RedisConnectionFactory.class) : C'est un très une annotation puissante. La personnalisation est prioritaire lors de la mise en œuvre de l’assemblage automatique. Indique que la JedisConnectionFactory par défaut sera utilisée uniquement si l'utilisateur n'injecte pas de manière personnalisée la classe RedisConnectionFactory.class.
réalise la dépendance entre les classes via diverses annotations. Lorsque le conteneur démarre Application.run, il appellera la méthode selectImports de la méthode EnableAutoConfigurationImportSelector.class (en fait sa classe parent)
selectImports finira par appeler la méthode SpringFactoriesLoader.loadFactoryNames pour obtenir une liste complète des BeanConfiguration
la méthodeloadFactoryNames lira FACTORIES_RESOURCE_LOCATION (c'est-à-dire spring.factories sous spring-boot-autoconfigure.jar), obtenez le nom complet ClassName de tous les beans liés à Spring, environ 120
la méthode selectImports continue d'appeler filter(configurations, autoConfigurationMetadata); à ce moment, elle filtrera un par un selon les conditions de ces BeanConfiguration, la chose la plus importante est @ConditionalOnClass. Cette annotation conditionnelle sera recherchée dans le chemin de classe pour voir s'il existe cette classe dépendante conditionnelle dans le package jar. Par conséquent, le package jar correspondant doit être disponible pour avoir ces classes dépendantes et générer certains beans de configuration par défaut requis par l'IOC.
Enfin, injectez la BeanConfiguration qualifiée dans la valeur de l'attribut dans la classe EnableConfigurationPropertie par défaut et injectez-la dans l'environnement IOC
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!