


Comment Springboot lit-il les listes, les tableaux, les collections de cartes et les objets dans les fichiers YML ?
application.yml définit la collection de listes
La première façon est d'utiliser l'annotation @ConfigurationProperties
pour obtenir toutes les valeurs de la collection de listes@ConfigurationProperties
注解获取list集合的所有值
type: code: status: - 200 - 300 - 400 - 500
编写配置文件对应的实体类,这里需要注意的是,定义list集合,先定义一个配置类Bean
,然后使用注解@ConfigurationProperties
注解来获取list集合值,这里给大家讲解下相关注解的作用
@Component 将实体类交给Spring管理
@ConfigurationProperties(prefix = “type.code”) 读取yml文件中的list
@Data 自动生成getter和setter方法
如下图所示
package com.o2o.data; import lombok.Data; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.context.annotation.Configuration; import java.util.List; @Component @ConfigurationProperties(prefix = "type.code") // 配置文件的前缀 @Data public class TypeCodeConfig { private List<String> status; public void setStatus(List<String> status){ this.status = status; } public List<String> getStatus(){ return status; } }
然后在要使用的地方自动注入,我是直接在启动类中读取这个list,需要注意,使用yml中配置的list需要先将对象注入,然后通过get方法读取配置文件中的的值。
@Autowired private TypeCodeConfig typeCodeConfig; 使用注解将对象注入
System.out.println(typeCodeConfig.getStatus()); 调用getter方法读取值
package com.o2o; import com.o2o.data.TypeCodeConfig; import org.mybatis.spring.annotation.MapperScan; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.CommandLineRunner; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration; @SpringBootApplication(exclude = {DataSourceAutoConfiguration.class}) @MapperScan("com.o2o.mapper") public class AutoTestApplication implements CommandLineRunner { public static void main(String[] args) { SpringApplication.run(AutoTestApplication.class, args); } @Autowired private TypeCodeConfig typeCodeConfig; @Override public void run(String... args) throws Exception { System.out.println(typeCodeConfig.getStatus());
启动springboot我们已经从控制台成功读取到yml文件中list集合的所有值了
第二种方式使用@value
注解获取list集合的所有值
yml文件配置如下
student: ids: - 7 - 8 - 9
然后创建一个实体类
@Data public class Student { @Value("${student.ids}") private List<Integer> ids; }
再新建一个对list属性的配置类
@Component @ConfigurationProperties(prefix = "student") @Data public class TypeCodeConfig { private List<Integer> ids; public void setIds(List<Integer> ids) { this.ids = ids; } public List<Integer> getIds(){ return ids; }
在启动类中注入
@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class}) @MapperScan("com.o2o.mapper") public class AutoTestApplication implements CommandLineRunner { public static void main(String[] args) { SpringApplication.run(AutoTestApplication.class, args); } @Autowired private TypeCodeConfig typeCodeConfig; @Override public void run(String... args) throws Exception { System.out.println(typeCodeConfig.getIds()); }
启动springboot我们已经从控制台成功读取到yml文件中list集合的所有值了
application.yml定义数组类型
yml配置文件如下图所示
dataSync: enable: true type: - "1" - "2" - "3"
通过@value注解获取数组值
@Value("${dataSync.enable.type}") private String[] type;
也可以通过创建配置类bean,使用@ConfigurationProperties注解
@Data @Component @ConfigurationProperties(prefix = "dataSync.enable") // 配置 文件的前缀 public class InterceptorPathBean { private String[] type; }
Bean
, puis utilisez l'annotation @ConfigurationProperties
pour obtenir la valeur de la collection de listes. Ici, nous expliquerons le rôle des annotations pertinentes
@Component remet la classe d'entité à la gestion Spring@ConfigurationProperties(prefix = "type.code") Lit la liste dans le fichier yml
@Data génère automatiquement des méthodes getter et setter
Comme le montre la figure ci-dessous
interceptorconfig: path: maps: name: 小明 age: 24
Ensuite, il est automatiquement injecté là où il doit être utilisé. J'ai lu cette liste directement dans la classe de démarrage, il convient de noter que lorsque vous utilisez la liste configurée dans yml, vous devez d'abord injecter l'objet, puis lire la valeur dans le fichier. fichier de configuration via la méthode get.
@Autowired private TypeCodeConfig typeCodeConfig; Utiliser des annotations pour injecter des objets dans
System.out.println(typeCodeConfig.getStatus()) ; Appelez la méthode getter pour lire la valeur
@Data @Component @ConfigurationProperties(prefix = "interceptorconfig.path") // 配置 文件的前缀 public class InterceptorPathBean { private Map<String , String> maps; }
Démarrez springboot Nous avons lu avec succès toutes les valeurs de la collection de listes dans le fichier yml depuis la console
Le deuxième la méthode utilise l'annotation @value
obtient toutes les valeurs de la collection de listes
student: id: 1 name: Bruce gender: male
students: - id: 1 name: Bruce gender: male - id: 2 name: ... ...
@ConfigurationProperties
, comme indiqué dans la figure ci-dessous : Les fichiers 🎜rrreee🎜yml peuvent également stocker des objets et des collections d'objets, en utilisant des méthodes et des types de base similaires. 🎜Exemple simple : 🎜🎜Définir la configuration de la collection de cartes🎜rrreee🎜En créant un bean de classe de configuration, utilisez l'annotation @ConfigurationProperties pour obtenir la valeur de la carte, comme indiqué dans la figure ci-dessous🎜rrreee🎜Utiliser la configuration d'objet🎜rrreee🎜Utiliser la configuration de la collection d'objets 🎜rrreee🎜Ici, je donne Résumons quelques points importants : 🎜🎜1. Dans le fichier de configuration yml du type de liste, vous devez utiliser "-" pour former une collection de listes. 🎜🎜2. Il n'y a pas de limite de niveau pour le préfixe dans yml. S'il est multi-niveau, comme demo/code ici, le préfixe pour configurer l'annotation ConfigurationProperties dans la classe java est écrit comme "demo.code"🎜🎜. 3. Le nom de l'attribut se trouve dans le fichier yml. Prend en charge le trait d'union "-", tel que four-span. Lors de la configuration des propriétés dans une classe Java, vous devez les convertir en casse camel, fourSpan. 🎜🎜4. Les attributs de la classe Java doivent être configurés avec les méthodes set et get. 🎜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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

1. Redis implémente le principe du verrouillage distribué et pourquoi les verrous distribués sont nécessaires. Avant de parler de verrous distribués, il est nécessaire d'expliquer pourquoi les verrous distribués sont nécessaires. Le contraire des verrous distribués est le verrouillage autonome. Lorsque nous écrivons des programmes multithreads, nous évitons les problèmes de données causés par l'utilisation d'une variable partagée en même temps. Nous utilisons généralement un verrou pour exclure mutuellement les variables partagées afin de garantir l'exactitude de celles-ci. les variables partagées. Son champ d’utilisation est dans le même processus. S’il existe plusieurs processus qui doivent exploiter une ressource partagée en même temps, comment peuvent-ils s’exclure mutuellement ? Les applications métier d'aujourd'hui sont généralement une architecture de microservices, ce qui signifie également qu'une application déploiera plusieurs processus si plusieurs processus doivent modifier la même ligne d'enregistrements dans MySQL, afin d'éviter les données sales causées par des opérations dans le désordre, les besoins de distribution. à introduire à ce moment-là. Le style est verrouillé. Vous voulez marquer des points

Springboot lit le fichier, mais ne peut pas accéder au dernier développement après l'avoir empaqueté dans un package jar. Il existe une situation dans laquelle Springboot ne peut pas lire le fichier après l'avoir empaqueté dans un package jar. La raison en est qu'après l'empaquetage, le chemin virtuel du fichier. n’est pas valide et n’est accessible que via le flux Read. Le fichier se trouve sous les ressources publicvoidtest(){Listnames=newArrayList();InputStreamReaderread=null;try{ClassPathResourceresource=newClassPathResource("name.txt");Input

Lorsque Springboot+Mybatis-plus n'utilise pas d'instructions SQL pour effectuer des opérations d'ajout de plusieurs tables, les problèmes que j'ai rencontrés sont décomposés en simulant la réflexion dans l'environnement de test : Créez un objet BrandDTO avec des paramètres pour simuler le passage des paramètres en arrière-plan. qu'il est extrêmement difficile d'effectuer des opérations multi-tables dans Mybatis-plus. Si vous n'utilisez pas d'outils tels que Mybatis-plus-join, vous pouvez uniquement configurer le fichier Mapper.xml correspondant et configurer le ResultMap malodorant et long, puis. écrivez l'instruction SQL correspondante Bien que cette méthode semble lourde, elle est très flexible et nous permet de

1. Personnalisez RedisTemplate1.1, mécanisme de sérialisation par défaut RedisAPI. L'implémentation du cache Redis basée sur l'API utilise le modèle RedisTemplate pour les opérations de mise en cache des données. Ici, ouvrez la classe RedisTemplate et affichez les informations sur le code source de la classe. Déclarer la clé, diverses méthodes de sérialisation de la valeur, la valeur initiale est vide @NullableprivateRedisSe

SpringBoot et SpringMVC sont tous deux des frameworks couramment utilisés dans le développement Java, mais il existe des différences évidentes entre eux. Cet article explorera les fonctionnalités et les utilisations de ces deux frameworks et comparera leurs différences. Tout d’abord, découvrons SpringBoot. SpringBoot a été développé par l'équipe Pivotal pour simplifier la création et le déploiement d'applications basées sur le framework Spring. Il fournit un moyen rapide et léger de créer des fichiers exécutables autonomes.

Dans les projets, certaines informations de configuration sont souvent nécessaires. Ces informations peuvent avoir des configurations différentes dans l'environnement de test et dans l'environnement de production, et peuvent devoir être modifiées ultérieurement en fonction des conditions commerciales réelles. Nous ne pouvons pas coder en dur ces configurations dans le code. Il est préférable de les écrire dans le fichier de configuration. Par exemple, vous pouvez écrire ces informations dans le fichier application.yml. Alors, comment obtenir ou utiliser cette adresse dans le code ? Il existe 2 méthodes. Méthode 1 : Nous pouvons obtenir la valeur correspondant à la clé dans le fichier de configuration (application.yml) via le ${key} annoté avec @Value. Cette méthode convient aux situations où il y a relativement peu de microservices. Méthode 2 : En réalité. projets, Quand les affaires sont compliquées, la logique

Cet article écrira un exemple détaillé pour parler du développement réel de dubbo+nacos+Spring Boot. Cet article ne couvrira pas trop de connaissances théoriques, mais écrira l'exemple le plus simple pour illustrer comment dubbo peut être intégré à nacos pour créer rapidement un environnement de développement.

Les principales façons dont SpringBoot lit les fichiers yml sont les suivantes : 1. Annotation @Value Nous pouvons utiliser l'annotation @Value sur les propriétés du bean pour lire directement la valeur dans yml, par exemple : application.yml:name:ZhangsanBean:publicclassMyBean{ @Value("${name}")privateStringname;}2.Objet Environment Nous pouvons lire la valeur yml en injectant l'objet Environment, tel que : @AutowiredprivateEnvironmentenv
