requisitos:
Quiero cargar las propiedades del servidor de application.yml a la clase de configuración. He visto que muchos ya han pedido misma pregunta, pero ninguno trabajado para mí :( me puede ayudar a la figura lo que me falta
@Configuration
@ConfigurationProperties("demo")
public class Democonfig {
private List<Archive> archive = new ArrayList<>();
public Democonfig(List<Archive> archive) {
this.archive = archive;
}
// Getter and setter
public static class Archive {
private String host;
private String database;
private String port;
public Archive(String host, String database, String port) {
this.host = host;
this.database = database;
this.port = port;
}
// Getters and setters
}
}
application.yml
demo:
archive:
-
host: "localhost"
database: "archive1"
port: "27017"
-
host: "localhost"
database: "archive2"
port: "27017"
mostrando su excepción
Binding to target [Bindable@129425f type = java.util.List<com.example.demo.config.Democonfig$Archive>, value = 'provided', annotations = array<Annotation>[[empty]]] failed:
Property: demo.archive[0].database
Value: archive1
Origin: class path resource [application.yml]:5:15
Reason: The elements [demo.archive[0].database,demo.archive[0].host,demo.archive[0].port,demo.archive[1].database,demo.archive[1].host,demo.archive[1].port] were left unbound.
Property: demo.archive[0].host
Value: localhost
Origin: class path resource [application.yml]:4:11
Reason: The elements [demo.archive[0].database,demo.archive[0].host,demo.archive[0].port,demo.archive[1].database,demo.archive[1].host,demo.archive[1].port] were left unbound.
Property: demo.archive[0].port
Value: 27017
Haga clic aquí ! para el código fuente completo y el proyecto cargado en git
Consorcio inactivo :
No sólo falta el arg constructor en la clase estática anidada
public static class Archive {
private String host;
private String database;
private String port;
public Archive() {
// TODO Auto-generated constructor stub
}
public Archive(String host, String database, String port) {
System.out.println("constri=uu Archive");
this.host = host;
this.database = database;
this.port = port;
}
public String getHost() {
return host;
}
public void setHost(String host) {
this.host = host;
}
public String getDatabase() {
return database;
}
public void setDatabase(String database) {
this.database = database;
}
public String getPort() {
return port;
}
public void setPort(String port) {
this.port = port;
}
@Override
public String toString() {
return "Archive [host=" + host + ", database=" + database + ", port=" + port + "]";
}
}
En realidad no hay necesidad de proporcionar constructor con setters y getters argument.Only se fine.I también alentaría U a la salida y el uso de Lombok, sería hacer que su concisa código de mano de papel.