spring-boot
Intégration Spring Boot-Hibernate-REST
Recherche…
Ajouter le support d'Hibernate
- Ajoutez la dépendance spring-boot-starter-data-jpa à pom.xml. Vous pouvez ignorer la balise de version si vous utilisez spring-boot-starter-parent comme parent de votre pom.xml . La dépendance ci-dessous apporte Hibernate et tout ce qui concerne JPA à votre projet ( référence ).
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
Ajoutez le pilote de base de données à pom.xml . Celui-ci est pour la base de données H2 ( référence ).
<dependency> <groupId>com.h2database</groupId> <artifactId>h2</artifactId> </dependency>
Activer la journalisation du débogage pour Hibernate dans application.properties
logging.level.org.hibernate.SQL = debug
ou dans application.yml
logging:
level:
org.hibernate.SQL: debug
Ajoutez la classe d'entité au package souhaité sous $ {project.home} / src / main / java / , par exemple sous com.example.myproject.domain ( référence ):
package com.example.myproject.domain; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; import java.io.Serializable; @Entity public class City implements Serializable { @Id @GeneratedValue public Long id; @Column(nullable = false) public String name; }
Ajoutez import.sql à $ {project.home} / src / main / resources / . Placez les instructions INSERT dans le fichier. Ce fichier sera utilisé pour la population de schéma de base de données à chaque démarrage de l'application ( référence ):
insert into city(name) values ('Brisbane'); insert into city(name) values ('Melbourne');
Ajoutez la classe de référentiel au package souhaité sous $ {project.home} / src / main / java / , par exemple sous com.example.myproject.service ( référence ):
package com.example.myproject.service; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; import java.io.Serializable; import com.example.myproject.domain.City; import org.springframework.data.domain.Page; import org.springframework.data.domain.Pageable; import org.springframework.data.repository.Repository; interface CityRepository extends Repository<City, Long> { Page<City> findAll(Pageable pageable); Page<City> findByName(String name); }
En gros c'est ça! À ce stade, vous pouvez déjà accéder à la base de données en utilisant les méthodes de com.example.myproject.service.CityRepository .
Ajouter le support REST
- Ajoutez la dépendance spring-boot-starter-web à pom.xml. Vous pouvez ignorer la balise de version si vous utilisez spring-boot-starter-parent comme parent de votre pom.xml ( référence ).
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
Ajouter le contrôleur REST au package souhaité, par exemple à com.example.myproject.web.rest ( référence ):
package com.example.myproject.web.rest; import java.util.Map; import java.util.HashMap; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import javax.servlet.http.HttpServletRequest; @RestController public class VersionController { @RequestMapping("/api/version") public ResponseEntity get() { final Map<String, String> responseParams = new HashMap(); responseParams.put("requestStatus", "OK"); responseParams.put("version", "0.1-SNAPSHOT"); return ResponseEntity.ok().body(responseParams.build()); } }
Démarrer l'application Spring Boot ( référence ).
Votre contrôleur est accessible à l'adresse http: // localhost: 8080 / api / version .