Projeto Web Services Spring Boot JPA
Projeto Web Services Spring Boot JPA
educandoweb.com
Dr. Nelio Alves
Objetivos
Criar projeto Spring Boot Java
Implementar modelo de domínio
Estruturar camadas lógicas: resource, service, repository
Configurar banco de dados de teste (H2)
Povoar o banco de dados
CRUD - Create, Retrieve, Update, Delete
Tratamento de exceções
Github:
https://github.com/acenelio/workshop-springboot2-jpa
Domain Model
Domain Instance
Logical Layers
Project created
Checklist:
File -> New -> Spring Starter Project
o Maven
o Java 11
o Packing JAR
o Dependencies: Spring Web Starter
Checklist:
JPA & H2 dependencies
application.properties
application-test.properties
Entity: JPA mapping
Dependencies:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<scope>runtime</scope>
</dependency>
application.properties:
spring.profiles.active=test
spring.jpa.open-in-view=true
application-test.properties:
spring.datasource.url=jdbc:h2:mem:testdb
spring.datasource.username=sa
spring.datasource.password=
spring.h2.console.enabled=true
spring.h2.console.path=/h2-console
spring.jpa.show-sql=true
spring.jpa.properties.hibernate.format_sql=true
Checklist:
UserRepository extends JPARepository<User, Long>
Configuration class for "test" profile
@Autowired UserRepository
Instantiate objects in memory
Persist objects
Objects:
User u1 = new User(null, "Maria Brown", "[email protected]", "988888888", "123456");
User u2 = new User(null, "Alex Green", "[email protected]", "977777777", "123456");
Objects:
Order o1 = new Order(null, Instant.parse("2019-06-20T19:53:07Z"), u1);
Order o2 = new Order(null, Instant.parse("2019-07-21T03:42:10Z"), u2);
Order o3 = new Order(null, Instant.parse("2019-07-22T15:21:22Z"), u1);
OrderStatus enum
Category
Objects:
Category cat1 = new Category(null, "Electronics");
Category cat2 = new Category(null, "Books");
Category cat3 = new Category(null, "Computers");
Product
Objects:
Product p1 = new Product(null, "The Lord of the Rings", "Lorem ipsum dolor sit amet, consectetur.", 90.5, "");
Product p2 = new Product(null, "Smart TV", "Nulla eu imperdiet purus. Maecenas ante.", 2190.0, "");
Product p3 = new Product(null, "Macbook Pro", "Nam eleifend maximus tortor, at mollis.", 1250.0, "");
Product p4 = new Product(null, "PC Gamer", "Donec aliquet odio ac rhoncus cursus.", 1200.0, "");
Product p5 = new Product(null, "Rails for Dummies", "Cras fringilla convallis sem vel faucibus.", 100.99, "");
Checklist:
OrderItemPK
OrderItem
Order one-to-many association
Seed
Objects:
OrderItem oi1 = new OrderItem(o1, p1, 2, p1.getPrice());
OrderItem oi2 = new OrderItem(o1, p3, 1, p3.getPrice());
OrderItem oi3 = new OrderItem(o2, p3, 2, p3.getPrice());
OrderItem oi4 = new OrderItem(o3, p5, 2, p5.getPrice());
Checklist:
UserService
UserResource
Test:
{
"name": "Bob Brown",
"email": "[email protected]",
"phone": "977557755",
"password": "123456"
}
User delete
Checklist:
UserService
UserResource
User update
Checklist:
UserService
UserResource
Test:
{
"name": "Bob Brown",
"email": "[email protected]",
"phone": "977557755"
}
Checklist:
NEW CLASS: services.exceptions.ResourceNotFoundException
NEW CLASS: resources.exceptions.StandardError
NEW CLASS: resources.exceptions.ResourceExceptionHandler
UserService
Exception handling - delete
Checklist:
NEW CLASS: services.exceptions.DatabaseException
ResourceExceptionHandler
UserService
o EmptyResultDataAccessException
o DataIntegrityViolationException
Checklist:
UserService
o EntityNotFoundException
Checklist:
Heroku Sign Up
Create app
Provision PostgreSQL
o App dashboard -> Resources
o Search "postgres" -> select "Heroku Postgres"
Checklist:
Download and install: https://www.postgresql.org/download/
o Super user: postgres
o Password: 1234567
o Port: 5432
Start/stop service: Task manager -> Services
Check instalation
o Start pgAdmin
o Databases -> Create -> Database
Encoding: UTF8
Dev profile
Checklist:
PgAdmin: create local database: create database springboot_course
<dependency>
<groupId>org.postgresql</groupId>
<artifactId>postgresql</artifactId>
<scope>runtime</scope>
</dependency>
spring.datasource.url=jdbc:postgresql://localhost:5432/springboot_course
spring.datasource.username=postgres
spring.datasource.password=1234567
spring.jpa.properties.hibernate.jdbc.lob.non_contextual_creation=true
spring.jpa.hibernate.ddl-auto=update
spring.jpa.show-sql=true
spring.jpa.properties.hibernate.format_sql=true
jwt.secret=MYJWTSECRET
jwt.expiration=3600000
Run application
Checklist:
App dashboard -> Settings - > Config Vars
EXAMPLE:
postgres://wavglvupbdad:358f443aafe452eca4c58fbc15d02e50b08130c7aaea3aff6c4f59c
[email protected]:5432/d7u9ub86cdsu
user: wavglvupbdad
password: 358f443aafe452eca4c58fbc15d02e50b08130c7aaea3aff6c4f59c13f9abb
server: ec2-23-21-106-266.compute-1.amazonaws.com
port: 5432
database: d7u9ub86cdsu
Create: application-prod.properties
spring.datasource.url=${DATABASE_URL}
spring.jpa.hibernate.ddl-auto=none
spring.jpa.show-sql=false
spring.jpa.properties.hibernate.format_sql=false
jwt.secret=${JWT_SECRET}
jwt.expiration=${JWT_EXPIRATION}
Update application.properties: spring.profiles.active=prod
java.runtime.version=11
Send to Heroku:
git add .
git commit -m "Deploy app to Heroku"
git push heroku master