spring-boot
Spring Boot- Hibernate-REST-integratie
Zoeken…
Ondersteuning voor Hibernate toevoegen
- Voeg afhankelijkheid van spring-boot-starter-data-jpa toe aan pom.xml. U kunt versie tag overslaan, als u gebruik maakt van de lente-boot-starter-ouder als de ouder van uw pom.xml. De afhankelijkheid hieronder brengt Hibernate en alles met betrekking tot JPA naar uw project ( referentie ).
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
Voeg databasestuurprogramma toe aan pom.xml . Deze hieronder is voor de H2-database ( referentie ).
<dependency> <groupId>com.h2database</groupId> <artifactId>h2</artifactId> </dependency>
Schakel foutopsporingsregistratie in voor Hibernate in application.properties
logging.level.org.hibernate.SQL = debug
of in application.yml
logging:
level:
org.hibernate.SQL: debug
Voeg entiteitsklasse toe aan het gewenste pakket onder $ {project.home} / src / main / java / , bijvoorbeeld onder com.example.myproject.domain ( referentie ):
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; }
Voeg import.sql toe aan $ {project.home} / src / main / resources / . Plaats INSERT- instructies in het bestand. Dit bestand wordt gebruikt voor databaseschemapopulatie bij elke start van de app ( referentie ):
insert into city(name) values ('Brisbane'); insert into city(name) values ('Melbourne');
Voeg de klasse Repository toe aan het gewenste pakket onder $ {project.home} / src / main / java / , bijvoorbeeld onder com.example.myproject.service ( referentie ):
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); }
Kortom, dat is het! Op dit moment hebt u al toegang tot de database met de methoden com.example.myproject.service.CityRepository .
REST-ondersteuning toevoegen
- Voeg afhankelijkheid van spring-boot-starter-web toe aan pom.xml. U kunt versie tag overslaan, als u gebruik maakt van de lente-boot-starter-ouder als de ouder van uw pom.xml ( referentie ).
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
Voeg de REST-controller toe aan het gewenste pakket, bijvoorbeeld aan com.example.myproject.web.rest ( referentie ):
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()); } }
Start de Spring Boot-toepassing ( referentie ).
Uw controller is toegankelijk op het adres http: // localhost: 8080 / api / version .