Servicio REST Api con Spring Data

Creamos un Proyecto Nuevo en https://start.spring.io/

Elegiremos Maven para la creación del ejemplo.

En la sección SQL elegimos JPA y PostgreSQL.

En la sección WEB elegimos Web y Rest Repositories

Finalizamos y descargamos el ejemplo. Debe quedar así en nuestro directorio.

Abrimos una terminal en el directorio y tecleamos:

mvn clean install

Maven se encargará de descargar las librerías necesarias para el proyecto.

Agregamos plugin para Eclipse IDE

mvn eclipse:eclipse

Ahora abrimos Eclipse e importamos proyecto Maven existente

Elegimos nuestro proyecto

Revisamos dependencias necesarias en el pom.xml

<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.codemonkey</groupId> <artifactId>api-rest</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>war</packaging> <name>api-rest-ejemplo</name> <description>Uso de API Rest Spring Data</description> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.9.RELEASE</version> <relativePath /> <!-- lookup parent from repository --> </parent> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-rest</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.postgresql</groupId> <artifactId>postgresql</artifactId> <scope>runtime</scope> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> <scope>provided</scope> </dependency> <!-- <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> --> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project><span data-mce-type="bookmark" id="mce_SELREST_start" data-mce-style="overflow:hidden;line-height:0" style="overflow:hidden;line-height:0" ></span>

Creamos una tabla alumno.

Insertamos valores.

INSERT INTO public.alumno(nombre, apellidos, direccion, telefono, email) VALUES ('Zuzanne', 'Waller', 'Tomahawk no. 100', '555-766', '[email protected]'),('Yohanan', 'Diaz', 'Toluca, Edo. Mex.', '555-111', '[email protected]');

Creamos clase Alumno.java

package com.codemonkey.entity; import java.io.Serializable; import javax.persistence.Entity; import javax.persistence.Table; import javax.persistence.Id; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Column; @Entity @Table(name="alumno") public class Alumno implements Serializable{ private static final long serialVersionUID = 1L; @Id @GeneratedValue(strategy = GenerationType.IDENTITY) @Column(name = "id") private int id; @Column(name = "nombre") private String nombre; @Column(name = "apellidos") private String apellidos; @Column(name = "direccion") private String direccion; @Column(name = "telefono") private String telefono; @Column(name = "email") private String email; public Alumno() {} public Alumno(int id, String nombre, String apellidos, String direccion, String telefono, String email) { super(); this.id = id; this.nombre = nombre; this.apellidos = apellidos; this.direccion = direccion; this.telefono = telefono; this.email = email; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getNombre() { return nombre; } public void setNombre(String nombre) { this.nombre = nombre; } public String getApellidos() { return apellidos; } public void setApellidos(String apellidos) { this.apellidos = apellidos; } public String getDireccion() { return direccion; } public void setDireccion(String direccion) { this.direccion = direccion; } public String getTelefono() { return telefono; } public void setTelefono(String telefono) { this.telefono = telefono; } public String getEmail() { return email; } public void setEmail(String email) { this.email = email; } @Override public String toString() { return "Alumno [id=" + id + ", nombre=" + nombre + ", apellidos=" + apellidos + ", direccion=" + direccion + ", telefono=" + telefono + ", email=" + email + "]"; } }

Creamos un Repositorio de datos

package com.codemonkey.repository; import org.springframework.data.repository.PagingAndSortingRepository; import com.codemonkey.entity.Alumno; public interface AlumnoRepository extends PagingAndSortingRepository<Alumno, Integer>{ }

Clases principales de la aplicación.
ApiRestEjemploApplication.java

package com.codemonkey; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class ApiRestEjemploApplication { public static void main(String[] args) { SpringApplication.run(ApiRestEjemploApplication.class, args); } }

SpringApplicationBuilder.java

package com.codemonkey; import org.springframework.boot.builder.SpringApplicationBuilder; import org.springframework.boot.web.support.SpringBootServletInitializer; public class ServletInitializer extends SpringBootServletInitializer { @Override protected SpringApplicationBuilder configure(SpringApplicationBuilder application) { return application.sources(ApiRestEjemploApplication.class); } }

application.properties

spring.data.rest.basePath=/api #MySQL #spring.datasource.url=jdbc:mysql://localhost:3306/proyecto #spring.datasource.username=root #spring.datasource.password=root #spring.datasource.driver-class-name=com.mysql.jdbc.Driver #POSTGRESQL spring.jpa.generate-ddl=true spring.jpa.show-sql=true spring.datasource.driverClassName=org.postgresql.Driver spring.datasource.url=jdbc:postgresql://localhost:5432/proyecto spring.datasource.username=postgres spring.datasource.password=5432 #spring.jpa.hibernate.ddl-auto=create-drop spring.jpa.hibernate.ddl-auto=update #spring.jpa.hibernate.ddl-auto=create spring.jpa.hibernate.naming-strategy=org.hibernate.cfg.ImprovedNamingStrategy # JPA (JpaBaseConfiguration, HibernateJpaAutoConfiguration) spring.jpa.database-platform=org.hibernate.dialect.PostgreSQLDialect

Ejecutamos la aplicación y abrimos el navegador en la dirección

http://localhost:8080/api/alumnoes

Links:

https://geeks-mexico.com/2018/01/04/crea-un-api-rest-de-la-forma-mas-simple-con-java-y-spring-data-rest/

https://start.spring.io/

Advertisements Share this:
Like this:Like Loading... Related