spring-boot
Spring Boot - Hibernate-REST Integration
Sök…
Lägg till viloläge-stöd
- Lägg till spring-boot-starter-data-jpa- beroende till pom.xml. Du kan hoppa version tag, om du använder fjäder boot-starter förälder som förälder till din pom.xml. Beroendet nedan ger Hibernate och allt relaterat till JPA till ditt projekt ( referens ).
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
Lägg till databasdrivrutin till pom.xml . Den här nedan är för H2-databas ( referens ).
<dependency> <groupId>com.h2database</groupId> <artifactId>h2</artifactId> </dependency>
Aktivera felsökning för viloläge i application.properties
logging.level.org.hibernate.SQL = felsökning
eller i applikation.yml
logging:
level:
org.hibernate.SQL: debug
Lägg till enhetsklass till önskat paket under $ {project.home} / src / main / java / , till exempel under com.example.myproject.domain ( referens ):
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; }
Lägg till import.sql till $ {project.home} / src / main / resources / . Lägg INSERT- uttalanden i filen. Denna fil kommer att användas för databasschemapopulation vid varje start av appen ( referens ):
insert into city(name) values ('Brisbane'); insert into city(name) values ('Melbourne');
Lägg till lagerklass till önskat paket under $ {project.home} / src / main / java / , till exempel under com.example.myproject.service ( referens ):
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); }
I grund och botten är det det! Vid denna punkt kan du redan komma åt databasen med metoderna från com.example.myproject.service.CityRepository .
Lägg till REST-stöd
- Lägg till vår-start-start- webbberoende till pom.xml. Du kan hoppa version tag, om du använder fjäder boot-starter förälder som förälder till din pom.xml ( referens ).
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
Lägg till REST-kontrollenhet till önskat paket, till exempel till com.example.myproject.web.rest ( referens ):
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()); } }
Starta Spring Boot-applikationen ( referens ).
Din controller är tillgänglig på adressen http: // localhost: 8080 / api / version .