Table of Contents
Desenvolvimento de APIs e Microsserviços 💻
Domine a criação de arquiteturas modernas de backend com Microsserviços, modelagem RESTful, segurança com JWT e o desenvolvimento de interfaces SPA modernas.
Foco do Curso
Metodologia: Aprendizado prático focado na construção de ecossistemas Fullstack, integrando serviços backend robustos com frontends de alta performance.
🎯 O Que Você Vai Aprender
-
Microsserviços --- Aprenda a decompor monólitos, gerenciar comunicação entre serviços e utilizar API Gateways para escalabilidade. Ir para Módulo 1
-
Modelagem RESTful --- Domine endpoints, status codes, documentação com Swagger/OpenAPI e padrões de projeto para APIs profissionais. Ver Modelagem
-
Autenticação JWT --- Implemente segurança de ponta a ponta com JSON Web Tokens, proteção de rotas e controle de acesso RBAC. Ver Segurança
-
Frontends SPA --- Integre seu backend com Single Page Applications modernas, explorando componentes, estados e roteamento dinâmico. Ver Projetos
📚 Jornada de Aprendizado (16 Aulas)
O curso é estruturado em quatro trilhas de especialização.
🧱 Módulo 1: Serviços e Microsserviços (Aulas 01-04)
- Aula 01 - Intro Microsserviços 🧩
- Aula 02 - Arquitetura e Gateway 🏗️
- Aula 03 - Modelagem REST 📡
- Aula 04 - Documentação (Swagger) 📄
🏗️ Módulo 2: CRUD e Persistência (Aulas 05-08)
- Aula 05 - Implementação de APIs ⚙️
- Aula 06 - Persistência e Banco 💾
- Aula 07 - Testes Unitários 🧪
- Aula 08 - Testes Integrados 🚢
🔌 Módulo 3: Autenticação e Segurança (Aulas 09-11)
🚀 Módulo 4: Aplicações Web SPA (Aulas 12-16)
- Aula 12 - Conceito de SPA 🌐
- Aula 13 - Componentes e Templates 🧱
- Aula 14 - Estados e Eventos 🔄
- Aula 15 - Roteamento 🛣️
- Aula 16 - Integração e Projeto Final 🎓
Plano de Ensino 📅
Curso: Desenvolvimento de APIs e Microsserviços (Backend & Frontend SPA)
Ementa
- Módulo 1: Serviços e Microsserviços: Conceitos, arquitetura distribuída, modelagem REST e documentação (OpenAPI).
- Módulo 2: Manipulação de Dados: Implementação backend, CRUD, persistência com ORM e testes unitários/integrados.
- Módulo 3: Autenticação e Autorização: Estratégias Web, JWT, proteção de rotas e segurança RBAC.
- Módulo 4: Aplicações Web SPA: Conceito de SPA, componentização, gerenciamento de estado, roteamento e integração final.
Cronograma (16 Aulas)
Módulo 1: Serviços e Microsserviços
- Aula 01: Introdução a Serviços e Microsserviços
- Aula 02: Arquitetura de Microsserviços e API Gateway
- Aula 03: Modelagem de APIs RESTful
- Aula 04: Documentação (Swagger) e Mock de APIs
Módulo 2: Manipulação de Dados via APIs REST
- Aula 05: Implementação de APIs (Controllers/Services/Rep)
- Aula 06: Persistência e Integração com Banco de Dados
- Aula 07: Testes Unitários com Mocks
- Aula 08: Testes Integrados e Build da Aplicação
Módulo 3: Autenticação e Autorização
- Aula 09: Estratégias Web (Sessions, Cookies, Tokens)
- Aula 10: Autenticação para APIs com JWT
- Aula 11: Autorização e Controle de Acesso (RBAC)
Módulo 4: Aplicações Web SPA
- Aula 12: Conceito de SPA e Estrutura de Projeto
- Aula 13: Componentes e Templates
- Aula 14: Gerenciamento de Estados e Eventos
- Aula 15: Roteamento e Navegação Dinâmica
- Aula 16: Formulários, Integração e Projeto Final
Avaliação
- Exercícios: 16 listas de exercícios teóricos e práticos.
- Projetos: 16 mini-projetos práticos de fixação.
- Quizzes: 16 testes de conhecimento imediato.
- Projeto Integrador: Desenvolvimento de uma aplicação Fullstack (API + SPA) para portfólio.
Aulas
Aula 01 - Introdução a Serviços e Microsserviços 🌐
Objetivo
Objetivo: Compreender a evolução das arquiteturas de software, diferenciar Monólitos de Microsserviços e entender o papel das APIs no ecossistema moderno de desenvolvimento.
1. O que são Serviços e Microsserviços? 🧩
No desenvolvimento moderno, um serviço é uma unidade funcional que entrega um valor específico (ex: processar um pagamento, enviar um e-mail).
🏛️ O Monólito
Historicamente, sistemas eram construídos como Monólitos: um único bloco de código onde tudo (interface, lógica, banco de dados) está fortemente acoplado.
- Vantagens: Simples de desenvolver inicialmente, fácil de testar localmente.
- Desvantagens: Difícil de escalar, uma falha em um módulo pode derrubar o sistema todo, barreira tecnológica (difícil mudar a linguagem após o início).
🏗️ Os Microsserviços
A arquitetura de Microsserviços decompõe a aplicação em serviços pequenos, independentes e focados em uma única responsabilidade (Single Responsibility Principle).
- Vantagens: Escalabilidade granular, resiliência (isolamento de falhas), liberdade tecnológica (cada serviço pode usar uma linguagem diferente).
- Desvantagens: Complexidade operacional, dificuldade em manter a consistência de dados, latência de rede.
2. Comparativo: Monólito vs Microsserviços ⚖️
| Característica | 🏛️ Monólito | 🏗️ Microsserviços |
|---|---|---|
| Escalabilidade | Vertical (Aumenta servidor) | Horizontal (Mais instâncias do serviço) |
| Deploy | Tudo ou nada | Independente por serviço |
| Falhas | Propagam-se facilmente | Isoladas ao serviço |
| Tecnologia | Única (Stack fixa) | Poliglota (Mix de linguagens) |
| Complexidade | Baixa no início, alta no final | Alta desde o início |
Visualização de Arquitetura (Mermaid)
graph TD
subgraph "Arquitetura de Microsserviços"
Client[Cliente/Web/App] --> AGW[API Gateway]
AGW --> S1[Serviço de Usuários]
AGW --> S2[Serviço de Pedidos]
AGW --> S3[Serviço de Pagamentos]
S1 --> DB1[(DB Usuários)]
S2 --> DB2[(DB Pedidos)]
S3 --> DB3[(DB Pagamentos)]
end
3. A Economia das APIs 📡
API (Application Programming Interface) é a "ponte" que permite a comunicação entre esses serviços ou entre sistemas diferentes.
- REST: O padrão de mercado baseado no protocolo HTTP.
- Endpoints: URLs específicas que expõem funcionalidades (ex:
GET /produtos). - Contratos: Acordos sobre como os dados devem ser enviados e recebidos (geralmente via JSON).
4. Ferramentas Essenciais 🛠️
Para trabalhar com backend e APIs, você precisará de um "cinto de utilidades" moderno:
- Client HTTP (Postman/Insomnia): Para testar endpoints sem precisar de um frontend.
- Docker: Para "empacotar" seus serviços e garantir que rodem em qualquer máquina.
- Git/GitHub: Para versionamento e colaboração.
- Runtime: Node.js, Java (JDK) ou Python (dependendo do projeto).
5. Estrutura de um Projeto Moderno 📂
Diferente de um app mobile, um ecossistema de microsserviços geralmente é organizado em Mono-repos ou Multi-repos.
Visão de Pastas (Padrão Backend)
$ ls -R backend-master
auth-service/ (Nodejs)
├── src/
├── package.json
└── Dockerfile
catalog-service/ (Java/Spring)
├── src/
├── pom.xml
└── Dockerfile
api-gateway/ (Go)
└── main.go
6. Mini-Projeto: Configurando o Cinto de Utilidades 🚀
Sua missão é preparar o ambiente para o desenvolvimento backend:
- Instalar o Visual Studio Code (ou IntelliJ CE).
- Instalar o Postman ou a extensão Thunder Client no VS Code.
- Instalar o Docker Desktop.
- Garantir que o Git esteja configurado no seu terminal.
Veja o passo a passo detalhado na seção Configuração > Setup Backend.
7. Exercício de Fixação 🧠
Responda em seu caderno/arquivo de notas:
- Explique o conceito de "Escalabilidade Horizontal" no contexto de microsserviços.
- Qual a função de um API Gateway em um sistema distribuído?
- Por que a consistência de dados é um desafio maior em microsserviços do que em monólitos?
Próxima Aula: Vamos mergulhar na Arquitetura de Microsserviços e API Gateway! 🏗️
Aula 02 - Arquitetura de Microsserviços e API Gateway 🏗️
Objetivo
Objetivo: Entender como múltiplos serviços independentes conversam entre si, o papel vital do API Gateway como porta de entrada e as estratégias de comunicação síncrona e assíncrona.
1. Comunicação entre Serviços 💬
Em um sistema distribuído, os serviços precisam trocar informações. Existem dois modelos principais:
🔄 Comunicação Síncrona (Sync)
O serviço chamador envia uma requisição e espera pela resposta imediata. * Protocolo: Geralmente HTTP/REST ou gRPC. * Exemplo: O serviço de Pedidos chama o serviço de Pagamentos e aguarda a confirmação para finalizar o carrinho. * Pró: Simples de entender e implementar. * Contra: Se o serviço destino estiver lento, todo o sistema fica lento (cascateamento).
📬 Comunicação Assíncrona (Async)
O serviço envia uma mensagem e não espera pela resposta. Ele continua seu trabalho. * Protocolo: Mensageria (RabbitMQ, Kafka, SQS). * Exemplo: O serviço de Pedidos envia um evento "Pedido Criado" para uma fila. O serviço de Logística lê essa fila quando puder. * Pró: Maior resiliência e desacoplamento. * Contra: Complexidade maior (consistência eventual).
2. O Papel do API Gateway 🚪
Em vez de expor todos os microsserviços diretamente para a internet, usamos um API Gateway. Ele atua como uma única porta de entrada para os clientes.
Responsabilidades do Gateway:
- Roteamento: Encaminha a requisição para o serviço correto (ex:
/usersvai paraUser-Service). - Autenticação: Verifica se o usuário está logado antes de passar a bola para os serviços internos.
- Rate Limiting: Impede que um cliente faça requisições demais e derrube o sistema.
- Agregação: Pode combinar dados de vários serviços em uma única resposta para o frontend.
3. Service Discovery e Load Balancing 🔍⚖️
Como o Gateway sabe o endereço de cada serviço se eles mudam de IP o tempo todo em containers?
🔎 Service Discovery
É uma agenda dinâmica (ex: Consul, Eureka) onde cada serviço se "registra" ao subir. O Gateway consulta essa agenda para achar o serviço.
⚖️ Load Balancing (Balanceamento de Carga)
Distribui as requisições entre várias instâncias do mesmo serviço para evitar sobrecarga.
graph TD
Client[Cliente/Mobile] --> Gateway[API Gateway]
Gateway --> SD{Service Discovery}
Gateway --> S1[Instância 1 - Pagamento]
Gateway --> S2[Instância 2 - Pagamento]
Gateway --> S3[Instância 3 - Pagamento]
style SD fill:#f9f,stroke:#333,stroke-width:4px
4. Padrões de Resiliência: Circuit Breaker 🔌
Se um serviço está falhando, não adianta continuar mandando requisições para ele. O Circuit Breaker (Disjuntor) "abre o circuito" e retorna um erro imediato ou um dado em cache, evitando que o erro se espalhe.
5. Mini-Projeto: Simulando um Gateway 🚀
Vamos simular o comportamento de um Gateway usando o Postman:
- Crie uma Collection chamada "API Gateway Simulation".
- Configure variáveis de ambiente para
base_url. - Crie rotas que "apontam" para diferentes APIs públicas (ex: JSONPlaceholder para posts e ReqRes para usuários).
- Teste como se fosse um único sistema centralizado.
Veja os detalhes práticos em Exercícios > Ex 02.
6. Exercício de Fixação 🧠
- Qual a diferença entre um API Gateway e um Load Balancer?
- Explique o problema do "Cascateamento de Falhas" em comunicações síncronas.
- Em que situação você usaria Kafka ao invés de HTTP para comunicar dois serviços?
Próxima Aula: Vamos colocar a mão na massa com a Modelagem de APIs RESTful! 📡
Aula 03 - Modelagem de APIs RESTful 📡
Objetivo
Objetivo: Dominar os princípios do design REST, aprender a usar corretamente os métodos HTTP, interpretar códigos de status e criar contratos de API profissionais e intuitivos.
1. O que é REST? 🧊
REST (Representational State Transfer) não é uma linguagem nem um framework, mas um estilo arquitetural para sistemas distribuídos.
Princípios Fundamentais:
- Client-Server: Separação clara entre quem pede (frontend/mobile) e quem atende (backend).
- Stateless: Cada requisição deve conter toda a informação necessária. O servidor não "lembra" do cliente entre chamadas.
- Cacheable: As respostas podem (e devem) ser cacheadas para melhorar a performance.
- Interface Uniforme: Uso padronizado de recursos, métodos e identificadores (URIs).
2. Recursos e URIs 📍
No REST, tudo é um recurso. Um recurso é qualquer dado que possa ser nomeado (um usuário, um produto, um pedido).
- Identificação: Usamos URIs (Uniform Resource Identifiers).
- Boas Práticas de Nomeação:
- Use substantivos no plural, nunca verbos.
GET /produtos✅ (Bom)GET /getTodosProdutos❌ (Ruim)- Use hierarquia:
GET /clientes/123/pedidos(Pedidos do cliente 123).
3. Verbos (Métodos) HTTP 🛠️
Os verbos dizem ao servidor o que fazer com o recurso:
| Verbo | Ação | Idempotente? |
|---|---|---|
| GET | Recupera um recurso ou lista. | Sim |
| POST | Cria um novo recurso. | Não |
| PUT | Atualiza um recurso inteiro (substituição). | Sim |
| PATCH | Atualiza apenas parte de um recurso. | Não |
| DELETE | Remove um recurso. | Sim |
O que é Idempotência? Significa que fazer a mesma requisição várias vezes tem o mesmo efeito que fazer uma única vez.
4. Códigos de Status (HTTP Status Codes) 🚦
A resposta do servidor deve vir com um código que indique o que aconteceu:
- 2xx (Sucesso):
200 OK: Deu tudo certo.201 Created: Recurso criado com sucesso (usado no POST).204 No Content: Sucesso, mas não há nada para retornar (usado no DELETE).
- 4xx (Erro do Cliente):
400 Bad Request: Requisição inválida (falta de dados).401 Unauthorized: Falta de autenticação.403 Forbidden: Autenticado, mas sem permissão.404 Not Found: Recurso não existe.
- 5xx (Erro do Servidor):
500 Internal Server Error: O servidor "quebrou".
5. O Formato JSON 🏗️
O JSON (JavaScript Object Notation) é o padrão de facto para troca de dados em APIs REST por ser leve e fácil de ler (por humanos e máquinas).
{
"id": 123,
"nome": "Smartphone X",
"preco": 1500.00,
"disponivel": true,
"categorias": ["Eletrônicos", "Ofertas"]
}
6. Mini-Projeto: Desenhando um Contrato ✍️
Imagine que você está criando uma API para uma Biblioteca.
- Defina a URI para listar todos os livros.
- Defina a URI e o Verbo para cadastrar um novo livro.
- Qual Status Code você retornaria se alguém tentasse deletar um livro que não existe?
- Desenhe o JSON de um objeto "Livro" com pelo menos 5 campos.
7. Exercício de Fixação 🧠
- Diferencie
PUTdePATCHcom um exemplo prático. - Por que não devemos usar verbos nas URIs (ex:
/deletarUsuario/123)? - O que significa uma API ser "Stateless"?
Próxima Aula: Vamos aprender a documentar essas APIs com Swagger e criar Mocks! 📝
Aula 04 - Documentação (Swagger) e Mock de APIs 📝
Objetivo
Objetivo: Compreender a importância da documentação para a Developer Experience (DX), aprender a usar o Swagger/OpenAPI para documentar contratos e entender como os Mocks permitem o desenvolvimento paralelo entre frontend e backend.
1. Por que documentar APIs? 🧐
Uma API sem documentação é como um labirinto no escuro. Se outros desenvolvedores (ou você mesmo no futuro) não souberem como chamar os endpoints, a API é inútil.
Benefícios:
- Developer Experience (DX): Facilita o consumo da API por terceiros.
- Single Source of Truth: O contrato documentado é a verdade absoluta do sistema.
- Redução de Erros: Menos ambiguidades sobre tipos de dados e status codes.
- Automação: Permite gerar clientes e testes automaticamente.
2. OpenAPI e Swagger 🛠️
O OpenAPI (antigamente chamado de Swagger) é o padrão mundial para descrever APIs RESTful.
- Arquivo YAML/JSON: Um arquivo que descreve rotas, parâmetros, modelos de dados e respostas.
- Swagger UI: Uma ferramenta visual que transforma esse arquivo em uma página interativa onde você pode testar a API.
# Exemplo simplificado de OpenAPI
paths:
/produtos:
get:
summary: Lista todos os produtos
responses:
'200':
description: Sucesso
3. O Poder dos Mocks 🎭
O que fazer quando o Frontend precisa de uma API que o Backend ainda não terminou de codificar? Usamos um Mock.
O que é um Mock?
É um servidor "fake" que simula o comportamento da API real. Ele recebe a requisição e retorna um dado estático pré-definido, conforme o contrato.
Ferramentas de Mock:
- Swagger Hub: Cria mocks automáticos a partir da documentação.
- Mockoon / Prism: Servidores locais para rodar mocks.
- Postman Mock Servers: Transforma uma collection em um servidor online.
4. Developer Experience (DX) 🚀
DX é o equivalente ao UX (User Experience), mas focado no programador. Uma API com boa DX possui:
* Nomes intuitivos.
* Documentação sempre atualizada.
* Exemplos de código em várias linguagens.
* Mensagens de erro claras (ex: "O campo 'email' é obrigatório" em vez de apenas 400 Bad Request).
5. Estrutura de Documentação Profissional 📂
Uma boa documentação de endpoint deve conter: 1. Título e Descrição: O que o endpoint faz? 2. Parâmetros: Quais dados enviar na URL (Path) ou no Filtro (Query)? 3. Corpo (Body): Qual o esquema do JSON de entrada? 4. Respostas: Quais Status Codes ele retorna e qual o JSON de saída para cada um?
6. Mini-Projeto: Criando Documentação no Swagger 🚀
Vamos criar um pequeno contrato para uma Loja de Games:
- Acesse o Editor do Swagger.
- Crie um endpoint
GET /gamesque retorna uma lista de objetos. - Adicione um parâmetro de filtro chamado
categoria. - Crie o modelo de dados para um
Game(id, titulo, plataforma, preco).
7. Exercício de Fixação 🧠
- Qual a diferença entre a Especificação OpenAPI e a Ferramenta Swagger?
- Como o uso de Mocks pode acelerar o cronograma de um projeto de software?
- Por que retornar apenas o Status Code (ex: 400) sem uma mensagem explicativa é considerado uma má prática de DX?
Próxima Aula: Fim do Módulo 1! No Módulo 2, iniciaremos a Implementação de APIs (Controllers/Services/Rep)! 💻
Aula 05 - Implementação de APIs (Controllers e Rotas) ⚙️
Objetivo
Objetivo: Entender a camada de entrada de uma aplicação backend, aprender a mapear rotas para funções específicas e capturar parâmetros de entrada enviados pelo cliente.
1. A Camada de Controller 🎮
O Controller é o "maestro" de uma rota. Sua única responsabilidade é: 1. Receber a requisição HTTP. 2. Validar se os dados básicos estão ali. 3. Chamar a lógica de negócio (que veremos na próxima aula). 4. Retornar a resposta correta (Status Code + JSON).
Analogie: O Controller é o garçom de um restaurante. Ele anota o pedido, leva para a cozinha e traz o prato pronto. Ele não cozinha!
2. Anatomia de uma Rota 📍
Uma rota no backend é composta por:
* Endpoint (Path): O caminho (ex: /produtos).
* Verbo: A ação (ex: POST).
* Handler: A função que será executada quando a rota for chamada.
Exemplo (Conceitual):
// Quando receber um GET em /usuarios, execute a função listarUuarios
router.get('/usuarios', (req, res) => {
const lista = [{ id: 1, nome: 'Ricardo' }];
return res.status(200).json(lista);
});
3. Capturando Dados do Cliente 📥
Existem três formas principais de o cliente enviar dados:
| Tipo | Onde fica? | Exemplo | Uso Comum |
|---|---|---|---|
| Path Params | Na URL (como parte do caminho) | /usuarios/123 |
Identificar um recurso específico. |
| Query Params | Na URL (após o ?) |
/produtos?categoria=games |
Filtros, ordenação e paginação. |
| Request Body | No "corpo" da mensagem | { "nome": "Novo Item" } |
Criação ou atualização (POST/PUT). |
4. O Objeto de Resposta (Response) 📤
Não basta retornar os dados, precisamos seguir o contrato REST.
O Controller deve garantir:
* Status Code Errado: Jamais retorne 200 OK se ocorreu um erro.
* Corpo Padronizado: Envie as mensagens de erro dentro de um JSON para facilitar o trabalho do frontend.
5. Injeção de Dependência (Introdutório) 💉
Para que o Controller não tenha que "criar" outras classes, ele as recebe prontas. Isso facilita testes e troca de tecnologias.
6. Mini-Projeto: Dashboard de Usuários 👥
- Crie uma rota
GET /usuarios. - Crie uma rota
POST /usuarios. - Crie uma rota
DELETE /usuarios/:id. - Use o Postman para testar se os dados estão sendo recebidos e enviados corretamente.
7. Mini-Projeto: Criando seu primeiro Controller ⌨️
Imagine que você está criando o Controller de um Carrinho de Compras.
- Defina a rota para adicionar um item (POST).
- Como você capturaria o
iddo produto vindo no Body? - Crie a rota para remover um item específico (DELETE via Path Param).
- Qual o Status Code ideal se o usuário tentar remover um item que não está no carrinho?
7. Exercício de Fixação 🧠
- Por que o Controller não deve conter regras de negócio (ex: cálculo de desconto)?
- Qual a diferença prática entre usar um Query Param e um Path Param?
- O que acontece se um Controller tentar acessar
req.bodymas o cliente não enviou o headerContent-Type: application/json?
Próxima Aula: Vamos tirar a lógica do Controller e levar para o lugar certo: Services e Regras de Negócio 🧠
Aula 06 - Services e Regras de Negócio 🧠
Objetivo
Objetivo: Entender a importância de separar a lógica de negócio da camada de transporte (HTTP), aprender a criar Services reutilizáveis e tratar erros de forma elegante.
1. Por que usar Services? 🏗️
Na aula anterior, aprendemos que o Controller é como um garçom. Ele não deve "cozinhar" (fazer cálculos ou validar regras complexas).
Se você colocar toda a lógica no Controller: 1. Código Duplicado: Se precisar da mesma lógica em outra rota, terá que copiar o código. 2. Difícil de Testar: Testar lógica misturada com HTTP é muito mais complexo. 3. Bagunça: O arquivo do Controller fica gigante e impossível de ler.
2. A Responsabilidade do Service ⚖️
O Service contém a Regra de Negócio. É aqui que o "cérebro" da aplicação reside.
O que o Service faz: * Valida se um usuário pode realizar uma ação (ex: "tem saldo suficiente?"). * Realiza cálculos (ex: "qual o valor do desconto progressivo?"). * Transforma dados antes de salvar (ex: "criptografar a senha"). * Lança erros claros quando algo dá errado.
3. O Fluxo de Execução 🌊
- Cliente faz o REQUEST.
- Controller captura os dados e chama o Service.
- Service processa a lógica e retorna o resultado (ou erro).
- Controller recebe o retorno e envia o RESPONSE para o cliente.
4. Tratamento de Erros Profissional ⚠️
Services não devem se preocupar com Status Codes (isso é coisa do Controller). O Service deve apenas avisar que algo falhou.
// Exemplo no Service
if (usuarioExiste) {
throw new Error("E-mail já cadastrado"); // Lança uma exceção
}
O Controller, então, captura esse erro e "traduz" para o HTTP:
// No Controller
try {
await service.cadastrar(dados);
} catch (erro) {
return res.status(400).json({ mensagem: erro.message });
}
5. ViewModels e DTOs (Data Transfer Objects) 📦
Muitas vezes, não queremos devolver todos os dados do banco para o cliente (ex: não queremos devolver a senha!). Usamos DTOs para filtrar o que entra e o que sai do sistema.
🆚 Comparação: MVVM (Mobile/Frontend)
Se você já ouviu falar de MVVM, o Service no Backend é muito similar ao papel do ViewModel no Frontend: ambos lidam com a lógica e os dados, deixando a "View" (ou Controller) limpa de complexidade.
6. Mini-Projeto: Refatorando para Service 🛠️
Imagine o sistema de Transferência Bancária.
1. Crie a função transferir(origem, destino, valor) no Service.
2. Quais validações você faria antes de confirmar a transferência? (Saldo, conta ativa, valores negativos...).
3. Simule o lançamento de um erro caso o saldo seja insuficiente.
7. Exercício de Fixação 🧠
- O que acontece com a manutenção do sistema se um Service for reaproveitado por dois Controllers diferentes?
- Por que o Service não deve saber que o
reqe oresdo Express existem? - Qual a vantagem de "limpar" os dados (DTO) antes de enviá-los ao cliente?
Próxima Aula: Onde guardamos esses dados? Repositories e Banco de Dados (PostgreSQL) 🗄️
Aula 07 - Repositories e Banco de Dados (PostgreSQL) 🗄️
Objetivo
Objetivo: Entender a camada de persistência, aprender os fundamentos de Bancos de Dados Relacionais (SQL) e como o padrão Repository isola o acesso aos dados da lógica de negócio.
1. Onde os dados moram? 🏠
Até agora, se reiniciarmos nosso servidor, todos os dados (usuários, produtos, etc) somem. Para que a informação sobreviva, precisamos de um Banco de Dados.
Neste curso, usaremos o PostgreSQL, um dos bancos relacionais mais robustos e utilizados no mundo backend.
2. Bancos Relacionais vs SQL 📊
Um banco relacional organiza os dados em Tabelas (linhas e colunas), como uma planilha de Excel gigante, mas com "superpoderes" de relacionamento.
O SQL (Structured Query Language) é a linguagem que usamos para falar com o banco.
Comandos Essenciais (CRUD):
- CREATE:
INSERT INTO tabela (campos) VALUES (valores); - READ:
SELECT * FROM tabela WHERE condicao; - UPDATE:
UPDATE tabela SET campo = valor WHERE id = 1; - DELETE:
DELETE FROM tabela WHERE id = 1;
3. Relacionamentos (O "Relacional") 🔗
O grande poder do SQL é ligar tabelas: * 1:N (Um para Muitos): Um Usuário tem muitos Pedidos. * N:N (Muitos para Muitos): Um Estudante está em muitos Cursos, e um Curso tem muitos Estudantes.
4. O Padrão Repository 📥
Assim como o Controller não deve "cozinhar", o Service não deve saber "falar SQL". O Service pede os dados para o Repository.
Vantagem: Se amanhã decidirmos trocar o PostgreSQL pelo MongoDB ou por um arquivo TXT, só precisamos mudar o Repository. O Service continua igual!
// Exemplo no Repository
async buscarPorId(id) {
return await db.query("SELECT * FROM usuarios WHERE id = $1", [id]);
}
5. Migrations: O Histórico do Banco 📜
Migrations são arquivos que descrevem as mudanças no banco de dados ao longo do tempo. * "Criar tabela de produtos". * "Adicionar coluna de preço". * "Remover coluna de descrição".
Isso permite que toda a equipe tenha sempre a mesma estrutura de banco.
6. Mini-Projeto: Modelando o Banco 🏗️
Imagine um sistema de Livraria. 1. Quais tabelas seriam necessárias? (Livros, Autores, Vendas). 2. Como você ligaria um Livro ao seu Autor? (Chave Estrangeira - Foreign Key). 3 Escreva o comando SQL para buscar todos os livros que custam menos de R$ 50,00.
7. Exercício de Fixação 🧠
- Qual a diferença entre uma Chave Primária (Primary Key) e uma Chave Estrangeira (Foreign Key)?
- Por que é perigoso deixar o Service rodar comandos SQL diretamente?
- O que acontece se executarmos um
DELETEsem a cláusulaWHERE? (⚠️ Cuidado!).
Próxima Aula: Como garantir que os dados que entram no banco estão corretos? Boas Práticas e Validação de Dados ✅
Aula 08 - Boas Práticas e Validação de Dados ✅
Objetivo
Objetivo: Aprender a garantir a integridade dos dados que entram no sistema, prevenir ataques comuns e escrever um código backend limpo, sustentável e fácil de manter.
1. Por que validar? 🛡️
O lema de todo desenvolvedor backend deve ser: "Nunca confie nos dados vindos do cliente". O frontend pode ter falhas ou alguém pode tentar burlar a interface e enviar dados maliciosos diretamente para a API.
Validar evita: * Dados Inconsistentes: Um produto sem preço ou um usuário sem e-mail. * Crashes: O servidor tentando processar algo que não existe. * Vulnerabilidades: Como nomes gigantes que quebram o layout ou scripts maliciosos.
2. Validação vs Sanitização 🧼
- Validação: Checar se o dado está correto (ex: "Isso é um e-mail válido?", "A idade é maior que 18?").
- Sanitização: Limpar o dado (ex: remover espaços em branco extras, remover tags HTML de um comentário).
3. Esquemas de Validação (Zod/Joi) 📐
Em vez de encher o Controller de if (campo == null), usamos bibliotecas de Schema Validation. Definimos um "contrato" e a biblioteca checa tudo para nós.
// Exemplo de esquema (Conceitual)
const usuarioSchema = {
nome: string().min(3),
email: string().email(),
idade: number().min(18)
};
4. Tratamento Global de Erros 🚨
Não devemos colocar try/catch em todas as funções. O ideal é ter um Middleware de Erro que captura qualquer falha inesperada e envia uma resposta padrão para o cliente.
Benefícios:
- O código fica limpo.
- As mensagens de erro para o cliente são amigáveis.
- Você pode logar o erro real no servidor para o time analisar sem expor detalhes sensíveis (como queries SQL) ao usuário final.
5. Clean Code: O Backend Elegante ✨
- Nomes Descritivos:
buscarUsuarioPorIdé melhor quegetUs. - Funções Pequenas: Se uma função faz 10 coisas, ela deve ser dividida.
- Princípio DRY: Don't Repeat Yourself (Não se repita). Se você usa o mesmo código em dois lugares, ele deve virar uma função ou utilitário.
🆚 Comparação: Clean Architecture no Mobile
Separar as regras de interface da lógica de validação é fundamental. O Clean Code é uma linguagem universal que separa o programador amador do profissional.
6. Mini-Projeto: O Validador de Produtos 🛒
Crie o esquema de validação para o cadastro de um Produto de E-commerce.
* nome: Obrigatório, mínimo 5 caracteres.
* preco: Obrigatório, deve ser maior que zero.
* estoque: Inteiro, não pode ser negativo.
* categoria: Deve ser uma das opções: 'Eletrônicos', 'Roupas' ou 'Alimentos'.
7. Exercício de Fixação 🧠
- Qual a diferença entre uma falha de validação (erro 400) e um erro inesperado no servidor (erro 500)?
- Por que sanitizar o texto de um comentário de usuário antes de salvá-lo no banco?
- O que acontece se uma API retornar detalhes técnicos do banco de dados (Stack Trace) em uma mensagem de erro para o cliente? (Dica: pense em segurança).
Próxima Aula: Entrando no Módulo 3! Segurança e Autenticação com JWT 🔐
Aula 09 - Segurança e Autenticação com JWT 🔐
Objetivo
Objetivo: Entender os conceitos de Autenticação e Autorização, aprender como funciona o padrão JWT (JSON Web Token) e como implementar um login seguro e sem estado (stateless).
1. Autenticação vs Autorização 🚦
Embora pareçam iguais, são processos diferentes: * Autenticação: "Quem é você?" (Validar e-mail e senha). * Autorização: "O que você pode fazer?" (Checar se você tem permissão de Admin, por exemplo).
2. O Problema das Sessões (Stateful) 🍪
Antigamente, o servidor guardava uma "sessão" na memória para cada usuário logado. * Problema: Se você tivesse 1 milhão de usuários, a memória do servidor estourava. * Problema 2: Se você tivesse dois servidores, o segundo não conheceria a sessão guardada no primeiro.
3. A Solução: JWT (Stateless) 🎫
O JWT (JSON Web Token) é como um "crachá digital". O servidor não guarda nada na memória. Ele entrega o crachá assinado para o usuário, e o usuário deve apresentar esse crachá em todas as próximas requisições.
Estrutura do JWT:
O token é composto por 3 partes separadas por pontos (.):
1. Header: Tipo do token e algoritmo de criptografia.
2. Payload: Os dados do usuário (ex: id, nome, permissões). Atenção: Não guarde senhas aqui, pois o payload é apenas codificado, não encriptado!
3. Signature: A "assinatura digital" que garante que o token não foi alterado.
4. O Fluxo do Login 🌊
- Cliente envia e-mail e senha.
- Servidor valida os dados no banco.
- Servidor gera um JWT usando uma "Chave Secreta" e envia para o cliente.
- Cliente armazena o token (geralmente no
localStorage). - Cliente envia o token no header
Authorizationem todas as rotas protegidas.
5. Implementando no Backend ⚡
Usamos bibliotecas como jsonwebtoken para assinar e validar os tokens.
// Gerando o token
const token = jwt.sign({ id: user.id }, 'CHAVE_SUPER_SECRETA', { expiresIn: '1d' });
🆚 Comparação: Keychain / EncryptedSharedPreferences (Mobile)
No Mobile, o JWT deve ser guardado com segurança máxima.
* Web: Usamos Cookies (HttpOnly) ou localStorage (com cautela).
Nunca guarde o JWT em texto simples no dispositivo!
6. Mini-Projeto: Gerador de Tokens 🛠️
- Crie uma função
login(email, senha). - Se o e-mail for "admin@teste.com" e a senha "123456", gere um JWT com o payload
{ role: 'admin' }. - Defina que esse token deve expirar em apenas 1 hora (
1h).
7. Exercício de Fixação 🧠
- Por que o JWT é chamado de "Stateless" (Sem estado)?
- O que acontece se uma pessoa mal-intencionada mudar o
rolede 'user' para 'admin' dentro do Payload do JWT? Por que a assinatura (Signature) impede isso? - Qual o perigo de usar uma "Chave Secreta" muito Curta ou óbvia (ex: "123")?
Próxima Aula: Como proteger rotas específicas? Controle de Acesso (RBAC) e Permissões 🛡️
Aula 10 - Controle de Acesso (RBAC) e Permissões 🛡️
Objetivo
Objetivo: Aprender a restringir o acesso a partes específicas da aplicação baseando-se no nível do usuário (Roles), utilizando o padrão RBAC (Role-Based Access Control) e Middlewares de autorização.
1. O que é RBAC? 👑
O RBAC (Role-Based Access Control) é um sistema onde você não dá permissão para um usuário específico, mas sim para um perfil (Role). * ADMIN: Pode criar, editar e deletar tudo. * EDITOR: Pode criar e editar, mas não deletar. * CLIENTE: Pode apenas visualizar o que é dele.
2. Middlewares de Autorização 🚧
Na aula passada, vimos a autenticação (login). Agora, precisamos de uma "cancela" que checa se o usuário logado tem o perfil certo para entrar em uma rota.
Como funciona:
1. O usuário envia o JWT.
2. O Middleware de Autenticação valida o token e extrai o id e o role.
3. O Middleware de Autorização checa: "Esse role está na lista de perfis permitidos?".
3. Implementando a Trava de Acesso 🔒
Criamos funções que geram middlewares dinamicamente.
// Exemplo conceitual
function autorizar(perfilNecessario) {
return (req, res, next) => {
if (req.usuario.role !== perfilNecessario) {
return res.status(403).json({ mensagem: "Acesso Negado: Você não é um " + perfilNecessario });
}
next(); // Tudo certo, pode passar!
};
}
4. Diferença entre 401 e 403 ❌
Estes dois códigos de erro são fundamentais no mundo da segurança: * 401 Unauthorized: "Não sei quem você é" (Token inválido, expirado ou ausente). * 403 Forbidden: "Eu sei quem você é, mas você não tem permissão para entrar aqui" (Ex: Cliente tentando entrar em rota de Admin).
5. Hierarquia de Permissões 🏛️
Em sistemas complexos, um Admin geralmente tem todas as permissões dos perfis abaixo dele.
* Se uma rota permite EDITOR, o ADMIN também deve conseguir entrar automaticamente.
6. Mini-Projeto: O Gerente de Notificações 📢
Imagine um app escolar.
1. Crie uma rota /avisos/enviar.
2. Apenas usuários com o role PROFESSOR ou DIRETOR podem acessar essa rota.
3. Implemente o middleware que barra usuários do tipo ALUNO.
7. Exercício de Fixação 🧠
- Por que é melhor usar Roles (Perfis) em vez de dar permissões específicas para cada ID de usuário?
- Em qual parte do token JWT costumamos guardar o
roledo usuário? - Uma rota protegida deve primeiro passar pelo middleware de Autenticação ou pelo de Autorização? Por quê?
Próxima Aula: Como manter o usuário logado com segurança? Refresh Token e Segurança Avançada 🧵
Aula 11 - Refresh Token e Segurança Avançada 🏗️
Objetivo
Objetivo: Aprender a lidar com a expiração de tokens usando o padrão Refresh Token, configurar políticas de acesso com CORS e fortalecer o servidor contra ataques comuns usando Headers de Segurança (Helmet).
1. O Problema do Token Expirado ⏰
Tokens JWT devem ter vida curta (ex: 15 minutos). * Se for eterno: Se alguém roubar o celular, terá acesso para sempre. * Se for curto: O usuário terá que fazer login a cada 15 minutos (péssima experiência!).
A Solução: Refresh Token 🔁
Quando o usuário faz login, ele recebe dois tokens: 1. Access Token: Curto (15 min). Usado em cada requisição. 2. Refresh Token: Longo (7 dias). Guardado no Banco de Dados. Ele serve apenas para pedir um novo Access Token quando o antigo expirar.
2. CORS: Quem pode me chamar? 🌍
O CORS (Cross-Origin Resource Sharing) é uma trava que o navegador usa.
* Se o seu site está em meusite.com e tenta chamar sua API em api.com, o navegador bloqueia por segurança, a menos que o servidor da API diga explicitamente: "Eu aceito chamadas de meusite.com".
No Backend (Express):
3. Helmet: Blindando os Headers 🪖
O Helmet é uma biblioteca que configura automaticamente vários cabeçalhos HTTP de segurança para esconder informações do seu servidor (ex: esconder que você usa Express) e prevenir ataques de injeção de scripts (XSS).
4. Proteção contra Brute Force 🔨
Se um hacker tentar 1 milhão de senhas por segundo, ele vai acabar entrando. * Rate Limit: Limitamos que o mesmo IP só pode tentar o login 5 vezes a cada minuto. * Se passar disso, o IP é bloqueado temporariamente.
5. XSS e SQL Injection (Revisão) ⚔️
- XSS: Injeção de scripts maliciosos no HTML. Previna limpando (sanitizando) o que o usuário digita.
- SQL Injection: Vimos na Aula 08. Use sempre Query Parameters ou ORMs.
6. Mini-Projeto: O Flow do Refresh 🔄
- Crie uma rota
/refresh. - Essa rota deve receber um
refreshToken. - Valide o token no banco de dados.
- Se for válido, gere um NOVO
accessTokene devolva para o usuário.
7. Exercício de Fixação 🧠
- Por que guardamos o Refresh Token no Banco de Dados, mas o Access Token não (Stateless)?
- O que acontece se você configurar o CORS com
origin: '*'? Por que isso é perigoso em produção? - Qual a vantagem de usar o Helmet em um servidor em vez de configurar cada Header manualmente?
Próxima Aula: Fim do Módulo de Segurança! Vamos entrar no mundo das Aplicações Web Modernas? Introdução a SPAs e Frontend Moderno 🎨
Aula 12 - Introdução ao Frontend Moderno (React) ⚛️
Objetivo
Objetivo: Entender o que são Single Page Applications (SPAs), conhecer o ecossistema do React e aprender a arquitetura baseada em componentes.
1. O que é uma SPA? 📄
Antigamente, cada clique em um site fazia a página "piscar" e recarregar tudo do zero (HTML, CSS, JS). Nas Single Page Applications (SPAs): * A página carrega apenas uma vez. * Quando você clica em algo, apenas o conteúdo necessário é trocado (via Javascript). * É muito mais rápido e parece um aplicativo de celular.
2. Por que React? 🚀
O React (criado pelo Facebook) é a biblioteca mais usada no mundo para criar interfaces modernas. * Componentização: Você cria pequenos pedaços (botões, menus, cards) e os junta como peças de LEGO. * Virtual DOM: O React é inteligente e só atualiza na tela o que realmente mudou, tornando tudo muito performático.
3. Vite: A Ferramenta de Próxima Geração ⚡
Para criar um projeto React, usamos o Vite. Ele é extremamente rápido para o desenvolvedor (o código carrega instantaneamente enquanto você edita).
4. O Coração do React: Componentes 🧩
Um componente é apenas uma função Javascript que retorna algo parecido com HTML (chamado de JSX).
function Saudacao() {
return (
<div className="card">
<h1>Olá, Mundo!</h1>
<p>Este é meu primeiro componente React.</p>
</div>
);
}
Regras do JSX:
- Você deve retornar apenas um elemento pai (ou usar um Fragment
<></>). - Use
classNameem vez declass(porqueclassé uma palavra reservada no Javascript).
5. Props: Passando Dados 🎁
Assim como passamos argumentos para funções, passamos Props para componentes.
function Usuario(props) {
return <h2>Bem-vindo, {props.nome}!</h2>;
}
// Usando o componente:
<Usuario nome="Ricardo" />
6. Mini-Projeto: Dashboard de Vendas 📊
- Crie um componente
CardResumoque recebetituloevalor. - Crie um componente
ListaVendasque exibe 3 vendas falsas. - Monte uma página simples juntando esses componentes.
7. Exercício de Fixação 🧠
- Qual a principal diferença entre um site tradicional (Multi Page) e uma SPA?
- Por que o uso de componentes facilita a manutenção de projetos grandes?
- O que é o JSX e por que ele não é exatamente HTML puro?
Próxima Aula: Como o React guarda informações? Hooks: useState e useEffect 🎣
Aula 13 - Estado e Reatividade (Hooks) 🎣
Objetivo
Objetivo: Aprender a tornar seus componentes vivos e interativos usando o hook useState, entendendo como o React reage a mudanças de dados.
1. O que é o "Estado" (State)? 🧠
Imagine um botão de curtir. O número de curtidas muda. No React, variáveis comuns NÃO fazem a tela atualizar. Para isso, usamos o Estado. * Variável Comum: Se o valor muda, a tela continua igual. * Estado (State): Se o valor muda, o React redesenha (re-renderiza) o componente na tela.
2. O Hook useState 🎣
O useState é uma função especial que nos dá duas coisas: o valor atual e uma função para mudar esse valor.
import { useState } from 'react';
function Contador() {
// valor: o número atual | setValor: a função para mudar
const [valor, setValor] = useState(0);
return (
<div>
<p>Você clicou {valor} vezes</p>
<button onClick={() => setValor(valor + 1)}>
Aumentar
</button>
</div>
);
}
3. Lidando com Eventos ⚡
No React, os eventos são muito parecidos com o HTML, mas usamos CamelCase:
* onclick ➔ onClick
* onchange ➔ onChange
* onsubmit ➔ onSubmit
4. Inputs Controlados ⌨️
Para pegar o que o usuário digita, conectamos o valor do input ao nosso estado.
function Formulario() {
const [nome, setNome] = useState("");
return (
<div>
<input
type="text"
value={nome}
onChange={(e) => setNome(e.target.value)}
placeholder="Digite seu nome"
/>
<p>Olá, {nome}!</p>
</div>
);
}
5. A Regra de Ouro: Nunca mude o estado diretamente ❌
Você nunca deve fazer isto: valor = valor + 1;.
Você deve sempre usar a função disparadora: setValor(valor + 1);.
Isso avisa ao React: "Ei, os dados mudaram! Desenha a tela de novo!".
6. Mini-Projeto: Lista de Compras Simples 🛒
- Crie um input e um botão "Adicionar".
- Use um estado para guardar a lista (um Array).
- Ao clicar, adicione o texto do input no array usando
setLista([...lista, novoItem]). - Exiba a lista usando
.map().
7. Exercício de Fixação 🧠
- O que acontece com a interface se você alterar uma variável comum
let contador = 0dentro de um componente? - Para que serve o segundo item retornado pelo
useState(a funçãoset...)? - Como limpamos um campo de input após o usuário clicar em um botão de enviar?
Próxima Aula: Ciclo de Vida e APIs! Hook: useEffect 🕒
Aula 14 - Efeitos e Chamadas de API (useEffect) 🌐
Objetivo
Objetivo: Entender o ciclo de vida de um componente React e aprender a buscar dados de APIs reais usando o hook useEffect.
1. O que são "Efeitos Colaterais"? 🧪
Em um componente, a tarefa principal é desenhar a tela. Qualquer coisa que aconteça "por fora" disso é um efeito colateral: * Buscar dados em uma API. { .fragment } * Mudar o título da aba do navegador. { .fragment } * Configurar um cronômetro (timer). { .fragment }
2. O Hook useEffect 🕒
O useEffect permite que você execute código em momentos específicos:
1. Quando o componente aparece na tela (Montagem).
2. Quando algum dado específico muda.
3. Sempre que o componente atualiza.
import { useEffect, useState } from 'react';
function Exemplo() {
useEffect(() => {
console.log("O componente apareceu na tela!");
}, []); // [] = Array de dependências vazio significa "executa só uma vez"
}
3. O Array de Dependências 🗃️
É o segundo argumento do useEffect. Ele diz ao React quando rodar o efeito de novo:
* []: Roda apenas na montagem.
* [contador]: Roda na montagem e toda vez que contador mudar.
* Sem array: Roda em toda e qualquer atualização (Cuidado! Pode causar loops infinitos).
4. Buscando Dados de uma API (Fetch) 📨
Vamos usar a API do GitHub como exemplo:
function PerfilGithub() {
const [usuario, setUsuario] = useState(null);
useEffect(() => {
fetch("https://api.github.com/users/ricardotecpro")
.then(response => response.json())
.then(data => setUsuario(data));
}, []);
if (!usuario) return <p>Carregando...</p>;
return (
<div>
<h1>{usuario.name}</h1>
<img src={usuario.avatar_url} alt="Avatar" />
</div>
);
}
5. Boas Práticas: Loading e Error 🛡️
Sempre que fizermos uma chamada de rede, devemos tratar três estados: 1. Loading: "Aguarde, estamos buscando...". 2. Success: Exibir os dados. 3. Error: "Ops, algo deu errado!".
6. Mini-Projeto: Dashboard de Clima ☁️
- Crie um estado para a cidade e outro para os dados do clima.
- Use o
useEffectpara buscar os dados de uma API de clima sempre que a cidade mudar. - Exiba a temperatura e a condição atual.
7. Exercício de Fixação 🧠
- O que acontece se esquecermos de passar o array de dependências
[]em umuseEffectque faz umfetche atualiza o estado? - Como fazemos para que um efeito seja executado apenas quando uma variável
IDmudar? - Para que serve o comando
response.json()após uma chamada defetch?
Próxima Aula: Navegação entre telas! React Router 🚦
Aula 15 - Navegação com React Router 🚦
Objetivo
Objetivo: Aprender a criar aplicações de múltiplas páginas (multi-page) dentro de uma SPA, configurando rotas, links e parâmetros de URL.
1. Por que precisamos de um Roteador? 🧭
Em uma Single Page Application (SPA), o navegador nunca "recarrega" de verdade. Se você clicar em um link comum, ele tenta buscar um novo arquivo HTML no servidor.
O React Router intercepta os cliques e troca apenas o componente na tela, mantendo a sensação de um site completo com /home, /sobre, etc.
2. Instalação e Configuração ⚙️
O roteador não vem no React por padrão. Precisamos instalar:
npm install react-router-dom
No seu App.jsx, configuramos a estrutura básica:
import { BrowserRouter, Routes, Route } from 'react-router-dom';
function App() {
return (
<BrowserRouter>
<Routes>
<Route path="/" element={<Home />} />
<Route path="/sobre" element={<Sobre />} />
<Route path="*" element={<NotFound />} />
</Routes>
</BrowserRouter>
);
}
3. Navegando entre Páginas 🏃♂️
Para mudar de página, nunca use a tag <a> comum, pois ela recarrega o site do zero. Use o componente <Link>:
import { Link } from 'react-router-dom';
function Navbar() {
return (
<nav>
<Link to="/">Início</Link>
<Link to="/sobre">Sobre</Link>
</nav>
);
}
4. Navegação Programática 🚀
Às vezes, queremos mudar de página via código (ex: após um login com sucesso). Para isso, usamos o hook useNavigate:
import { useNavigate } from 'react-router-dom';
function Login() {
const navigate = useNavigate();
const handleLogin = () => {
// ... lógica de login
navigate("/dashboard");
};
}
5. Parâmetros de URL (Hooks) 🆔
Como exibir uma página específica de um produto (ex: /produto/123)? Usamos o caractere : na rota:
- Rota:
<Route path="/produto/:id" element={<Detalhes />} /> - Captura: No componente
Detalhes, usamos o hookuseParams.
import { useParams } from 'react-router-dom';
function Detalhes() {
const { id } = useParams();
return <h1>Exibindo o produto ID: {id}</h1>;
}
6. Mini-Projeto: Blog de TecPro 📰
- Crie uma página inicial que lista 3 posts (objetos simples).
- Crie uma rota dinâmica
/post/:id. - Ao clicar no link do post, o usuário deve ser levado para a página de detalhes que mostra o ID do post acessado.
7. Exercício de Fixação 🧠
- Qual a principal diferença visual entre usar
<a href="...">e<Link to="...">em um app React? - Para que serve o
path="*"em uma configuração de rotas? - Se você quiser criar uma área de "Perfil do Usuário" onde a URL é
/u/ricardo, como ficaria a definição dopathno componenteRoute?
Próxima Aula: O grande final! Projeto Full-Stack Integrado 🏆
Aula 16 - Projeto Final e Conclusão 🏆
Objetivo
Objetivo: Aplicar TODO o conhecimento adquirido (Node.js, Express, JWT, RBAC, React, Hooks e Router) para criar uma aplicação Full-Stack completa e funcional.
1. O Desafio Final: "TecPro Connect" 🔗
Você deve criar uma plataforma web completa que conecte seu Frontend ao seu Backend. Escolha UM dos temas abaixo ou crie o seu:
- Gerenciador de Tarefas Cloud: Sistema de login, cadastro de tarefas com categorias, salvamento no banco de dados e filtros de status.
- Mini E-commerce: Listagem de produtos vindo da API, página de detalhes, "carrinho" (estado global) e simulação de checkout.
- Rede Social de Bolso: Postagem de mensagens (tweets), perfil de usuário dinâmico e curtidas (likes) em tempo real.
- Sistema de Chamados (Helpdesk): Usuário abre o ticket (Frontend) e o Admin visualiza e altera o status (Backend com permissões RBAC).
2. Requisitos Obrigatórios (Checkout) 📋
O projeto integrado deve conter obrigatoriamente:
- [ ] Backend em Node.js: Pelo menos 3 rotas protegidas por JWT.
- [ ] Frontend em React: Interface moderna, responsiva e baseada em componentes.
- [ ] Integração (Fetch): O site deve buscar dados reais da sua API local ou hospedada.
- [ ] Navegação: Uso de React Router para pelo menos 3 páginas (Login, Home, Perfil).
- [ ] Estado: Uso de useState e useEffect para gerenciar os dados.
3. Dicas para um Portfólio Arrasador ✨
Para que seu projeto chame a atenção de empresas: 1. README.md Profissional: Explique o problema que você resolveu, como rodar o projeto (frontend e backend) e liste as tecnologias (ex: Vite, Express, Helmet). 2. Tratamento de Erros: Se o servidor cair, o frontend deve avisar o usuário amigavelmente. 3. Aesthetics: Capriche no CSS! Use cores harmônicas e uma tipografia limpa. 4. Segurança: Não esqueça de configurar o CORS no backend para aceitar os pedidos do seu frontend.
4. Onde continuar estudando? 📚
A jornada de um desenvolvedor Full-Stack está apenas começando. O que aprender agora? 1. TypeScript: O "superpoder" do Javascript para evitar erros de tipos. 2. Bancos de Dados SQL: Postgres ou MySQL para aplicações ainda mais robustas. 3. Next.js: O framework React que domina o mercado atual (com SSR e rotas nativas). 4. Docker: Para empacotar sua aplicação e rodar em qualquer lugar.
5. Mensagem Final 🌟
Parabéns! Você saiu do básico de requisições HTTP e hoje é capaz de construir uma ponte sólida entre o usuário e os dados. Você domina a arte de criar APIs seguras e interfaces vivas.
"A tecnologia é apenas uma ferramenta. Em termos de conseguir que as pessoas trabalhem juntas e as motivem, o desenvolvedor é o artista."
FIM DO CURSO 🚀🚀🚀 Desejamos muito sucesso na sua jornada como Desenvolvedor Full-Stack!
Exercícios
Listas de Exercícios 🏋️
Pratique o que aprendeu com desafios graduais para cada aula.
-
Módulo 1: Fundamentos de Backend ---
-
Módulo 2: Manipulação de Dados ---
-
Módulo 3: Segurança e Autenticação ---
-
Módulo 4: Aplicações SPA (React) ---
Exercícios 01 - Introdução a Microsserviços 🧩
🟢 Fáceis
- Definição: Explique com suas palavras o que é um microsserviço.
- Diferenciação: Cite 3 desvantagens de um sistema Monolítico em relação a uma arquitetura de Microsserviços.
🟡 Médios
- Cenário: Uma startup de delivery começou com um monólito e agora está sofrendo para atualizar o sistema de pagamentos sem quebrar o rastreamento de pedidos. Qual vantagem dos microsserviços resolveria esse problema? Justifique.
- Conectividade: O que é uma API e por que ela é fundamental na integração de sistemas distribuídos?
🔴 Desafio
- Análise de Arquitetura:
Imagine o sistema do "Netflix". Ele possui milhões de usuários acessando simultaneamente filmes, perfis e faturas.
- Se o serviço de "Busca" falhar, o usuário deve ser impedido de assistir aos filmes que já estão na sua lista "Continuar Assistindo"? Como a arquitetura de microsserviços ajuda nesse isolamento?
- Desenhe/Escreva como seria a divisão básica: Quais seriam os pelo menos 4 serviços independentes que você criaria para o Netflix?
Exercícios 02 - Arquitetura e Gateway 🏗️
🟢 Fáceis
- Conceitos: Explique o que é um API Gateway com uma analogia da vida real (ex: uma recepção de hotel).
- Síncrono vs Assíncrono: Diferencie os dois modelos de comunicação em uma frase cada.
🟡 Médios
- Resiliência: O que acontece com um sistema distribuído que só usa comunicação síncrona se o serviço de banco de dados ficar muito lento? Como isso afeta o usuário final?
- Segurança: Por que é melhor colocar a lógica de autenticação no API Gateway do que repetir em cada um dos 20 microsserviços?
🔴 Desafio
- Cenário de Falha Crítica:
O serviço de "Notificação" (envio de e-mail e SMS) está fora do ar.
- Se o seu sistema for síncrono, o usuário conseguirá finalizar uma compra?
- Como a abordagem assíncrona com filas resolveria esse problema, garantindo que o e-mail seja enviado quando o serviço voltar?
- Cite um exemplo de serviço que precisa ser síncrono (não pode esperar).
Exercícios 03 - Modelagem REST 📡
🟢 Fáceis
- URI Design: Corrija as URIs abaixo para seguirem as boas práticas REST:
GET /listar_todos_usuariosPOST /criarNovoPedidoDELETE /remover-produto-por-id/123
- Verbos: Qual o verbo HTTP mais adequado para atualizar a senha de um usuário? Por que?
🟡 Médios
- Status Codes: Escolha o código de status ideal para as situações:
- Usuário tentou deletar um arquivo, mas ele não tem permissão de administrador.
- O cadastro foi realizado com sucesso e o sistema retornou os dados do novo usuário.
- O servidor caiu por falta de memória.
- Idempotência: Explique por que o
POSTnão é idempotente e oGETé.
🔴 Desafio
- Design de Contrato:
Desenhe as rotas para um sistema de E-commerce.
- Como seria a URI para listar todos os itens de um carrinho específico?
- Como seria a URI para adicionar um item a este carrinho?
- Escreva o JSON que representaria um "Item de Carrinho" com:
produto_id,nome,quantidadeepreco_unitario.
Exercícios 04 - Documentação e Mocks 📝
🟢 Fáceis
- Conceitos: O que é OpenAPI e qual a relação dela com o Swagger?
- Mocks: Explique com suas palavras por que um desenvolvedor Frontend desejaria usar um Mock Server.
🟡 Médios
- Análise de YAML: Analise o trecho OpenAPI abaixo e responda: Qual o endpoint? Qual o verbo? O que ele retorna no sucesso?
- Developer Experience (DX): Imagine que você recebeu uma documentação que diz apenas:
POST /login - Envie os dados do usuário. Por que essa documentação é ruim sob a ótica de DX?
🔴 Desafio
- Cenário de Desenvolvimento:
Você é o arquiteto de um projeto onde o Backend vai demorar 3 semanas para liberar a primeira API, mas o Frontend precisa começar amanhã.
- Como você organizaria o trabalho usando Mocks?
- Como garantir que, quando o Backend ficar pronto, a integração ocorra sem precisar mudar nada no código do Frontend?
- Cite uma ferramenta que você usaria para subir esse Mock Server rapidamente.
Exercícios 05 - Implementação de APIs ⚙️
🟢 Fáceis
- Responsabilidade: Qual a principal função de um Controller em uma arquitetura de camadas?
- Mapeamento: O que é um "Handler" no contexto de rotas backend?
🟡 Médios
- Parâmetros: Diferencie, com exemplos de URIs, o uso de Path Params e Query Params.
- Erros: Por que o Controller nunca deve retornar uma resposta sem um Status Code explícito?
🔴 Desafio
- Cenário Real:
Imagine que você está implementando a rota de
PUT /produtos/123.- Como você capturaria o
123? - Como você capturaria o novo nome do produto?
- Em qual objeto (
req.params,req.queryoureq.body) cada um desses dados estaria? - O que você faria se o cliente enviasse o
idno Body diferente doidna URL?
- Como você capturaria o
Exercícios 06 - Services e Regras de Negócio 🧠
🟢 Fáceis
- Conceito: Explique por que não é uma boa prática colocar lógica de cálculo ou validação dentro do Controller.
- Responsabilidade: Cite 3 exemplos de tarefas que devem ser feitas na camada de Service.
🟡 Médios
- Tratamento de Erros: Por que o Service deve lançar (throw) um erro em vez de retornar um Status Code (ex: 404)?
- Reutilização:
Imagine que você tem um
EmailService. Cite dois Controllers diferentes que poderiam usar esse mesmo serviço.
🔴 Desafio
- Lógica de Negócio:
Escreva o pseudocódigo para um
PedidoService.finalizar(pedidoId).- Quais validações você faria? (Estoque, status do pedido, limite de crédito do cliente).
- Como você lidaria com o caso de "Produto Sem Estoque"?
- Qual tipo de dado (DTO) o Service deveria retornar para o Controller após o sucesso?
Exercícios 07 - Repositories e Banco de Dados 🗄️
🟢 Fáceis
- Fundamentos: O que significa a sigla SQL e para que ela serve?
- CRUD: Escreva o comando SQL para inserir um novo produto (nome "Mouse", preço 50.00) na tabela
produtos.
🟡 Médios
- Relacionamentos: Explique a diferença entre uma Primary Key (PK) e uma Foreign Key (FK). Por que a FK é essencial para bancos relacionais?
- Isolamento: Por que usamos o padrão Repository em vez de escrever o código SQL diretamente dentro do Service?
🔴 Desafio
- Modelagem Real:
Imagine um sistema de Blog. Temos
EscritoreseArtigos.- 1:N: Como você modelaria a ligação entre um Escritor e seus Artigos?
- SQL: Escreva uma query que retorne o título de todos os artigos escritos pelo autor com
id = 5. - Repository: Como ficaria a assinatura (nome e parâmetros) da função no
ArtigoRepositoryresponsável por essa busca?
Exercícios 08 - Boas Práticas e Validação de Dados ✅
🟢 Fáceis
- Conceito: Por que nunca devemos confiar 100% nos dados vindos do frontend?
- Validação: Dê um exemplo de uma regra de validação para um campo de "Senha".
🟡 Médios
- Sanitização: Qual a diferença prática entre validar um campo e sanitizar um campo? Quando usamos cada um?
- Clean Code: Refatore o nome da função abaixo para seguir as boas práticas:
🔴 Desafio
- Tratamento de Erros:
Imagine que o banco de dados caiu. O Service lança um erro técnico.
- Como o Middleware Global de Erros deve reagir?
- O que ele deve enviar para o usuário final? (Erro 500 com mensagem técnica ou mensagem genérica?)
- Por que é importante logar o erro real apenas no console do servidor?
Exercícios 09 - Segurança e Autenticação com JWT 🔐
🟢 Fáceis
- Conceito: Qual a principal diferença entre Autenticação e Autorização?
- JWT: Quais são as 3 partes de um token JWT?
🟡 Médios
- Segurança: Por que nunca devemos incluir informações sensíveis (como a senha do usuário) dentro do Payload do JWT?
- Stateless: Quais as vantagens de uma arquitetura "Stateless" em sistemas que precisam escalar para milhões de usuários?
🔴 Desafio
- Análise de Token:
Imagine que você interceptou um token JWT.
- Como você faria para ler o nome do usuário que está dentro dele sem saber a chave secreta?
- Agora, imagine que você tentou mudar o
iddo usuário para burlar o sistema. Por que o servidor vai rejeitar esse token quando você tentar usá-lo? - Onde o frontend deve armazenar o token para que ele não suma quando a página for recarregada?
Exercícios 10 - Controle de Acesso (RBAC) 🛡️
🟢 Fáceis
- Conceito: No sistema RBAC, o que é uma "Role"?
- Status Code: Se um usuário comum tenta acessar uma área de administrador, qual o código de erro HTTP (Status Code) mais apropriado?
🟡 Médios
- Diferença: Explique a diferença fundamental entre erro 401 e erro 403. Em qual desses casos o usuário deve ser redirecionado para a tela de login?
- Middleware:
Imagine que você tem uma rota
/admin/dashboard. Quais seriam os dois middlewares (nesta ordem) que o usuário deveria passar antes de chegar no Controller final?
🔴 Desafio
- Hierarchy (Hierarquia):
Implemente (em pseudocódigo) uma lógica onde a função
autorizar(['EDITOR', 'ADMIN'])permita a passagem se o usuário logado tiver QUALQUER um desses dois perfis.- Como você garantiria que um
ADMINsempre consiga acessar rotas deUSEReEDITORsem precisar listar oADMINem todas as rotas do sistema? - Qual a vantagem dessa abordagem centralizada?
- Como você garantiria que um
Exercícios 11 - Refresh Token e Segurança Avançada 🏗️
🟢 Fáceis
- Conceito: Por que Access Tokens costumam ter vida curta?
- Bibliotecas: Para que serve a biblioteca Helmet em um aplicativo Express?
🟡 Médios
- CORS: Explique por que o CORS é uma segurança do Navegador e não do servidor. O que acontece se você tentar chamar uma API sem CORS a partir de um script no Terminal (cURL)?
- Flow: Desenhe o fluxo de uma requisição que retorna erro 401 por token expirado e como o frontend deve agir para usar o Refresh Token.
- Headers: Cite três informações sensíveis que o Helmet ajuda a esconder nos cabeçalhos HTTP.
🔴 Desafio
- Segurança de Refresh Tokens:
Se o Refresh Token permite gerar novos Access Tokens, por que ele é considerado mais seguro?
- Onde ele deve ser armazenado preferencialmente no navegador (LocalStorage ou Cookies HttpOnly)? Por quê?
- O que é o "Refresh Token Rotation"?
Exercícios 12 - Introdução ao React ⚛️
🟢 Fáceis
- Conceito: O que significa a sigla SPA e qual sua principal vantagem?
- Sintaxe: No React, usamos
classNameouclasspara definir classes CSS? Por quê?
🟡 Médios
- Componentes: Por que dizemos que a arquitetura do React é baseada em "LEGO"? Como isso ajuda na organização do código?
- Vite: Qual a função do Vite no desenvolvimento de um projeto React moderno?
- Props:
Explique como as
propspermitem que um mesmo componente (ex: um Botão) seja usado em vários lugares com textos e cores diferentes.
🔴 Desafio
- JSX vs HTML:
O código abaixo é Javascript ou HTML? Justifique sua resposta mencionando pelo menos duas diferenças sutis que o JSX impõe.
- O que acontece se eu esquecer de fechar a tag
<br>? - Como eu faria para exibir o valor de uma variável
nomedentro doh1?
- O que acontece se eu esquecer de fechar a tag
Exercícios 13 - Estado e Reatividade (Hooks) 🎣
🟢 Fáceis
- Conceito: Por que uma variável comum (ex:
let x = 0) não serve para atualizar um contador na tela do React? - Sintaxe: O que faz o comando
const [valor, setValor] = useState(0);? Explique cada um dos 3 elementos.
🟡 Médios
- Eventos: Como passamos uma função que deve ser executada apenas quando o usuário clica em um botão? Mostre um exemplo de código.
- Imutabilidade:
Por que não podemos fazer
lista.push(item)e depoissetLista(lista)no React? Qual o jeito correto de adicionar um item a um array no estado? - Inputs:
O que é um "Input Controlado" e como o atributo
valuee o eventoonChangetrabalham juntos?
🔴 Desafio
- Toggle de Visibilidade:
Crie a lógica para um componente que esconde ou mostra um texto secreto.
- Qual tipo de dado você usaria no
useState(Boolean, String ou Number)? - Como ficaria a expressão JSX para mostrar o texto apenas se o estado for verdadeiro?
- Qual tipo de dado você usaria no
Exercícios 14 - Efeitos e Chamadas de API 🌐
🟢 Fáceis
- Conceito: O que é um "Efeito Colateral" (Side Effect) no desenvolvimento Frontend?
- useEffect: O que acontece se passarmos um array de dependências vazio
[]para ouseEffect?
🟡 Médios
- Dependências:
Se eu quiser que o
useEffectrode sempre que a variávelusuarioIDmudar, como deve ficar o array de dependências? - Fetch: Explique a ordem de execução do código abaixo:
- Estados de Rede:
Por que é importante ter um estado de
loading(carregando) em aplicações que buscam dados na internet?
🔴 Desafio
- Ciclo de Efeitos:
Imagine que seu efeito faz um
fetche, dentro do.then(), você chama umsetData(dados).- O que acontece se você NÃO passar o array
[]? Explique o loop infinito que isso gera. - Como você faria para exibir uma mensagem "Nenhum resultado encontrado" caso a API retorne um array vazio?
- O que acontece se você NÃO passar o array
Exercícios 15 - Navegação com React Router 🚦
🟢 Fáceis
- Conceito: Por que usamos o React Router em vez de links
<a>comuns em uma SPA? - Componentes: Para que servem os componentes
<BrowserRouter>e<Routes>?
🟡 Médios
- Navegação:
Qual a diferença entre usar o componente
<Link>e o hookuseNavigate? Em quais situações você usaria cada um? - Rota 404: Como configuramos uma rota que deve ser exibida quando o usuário digita uma URL que não existe no site?
- Parâmetros:
Dada a rota
<Route path="/usuario/:nome" element={<Perfil />} />, como o componentePerfilpode descobrir qual o nome que foi digitado na URL?
🔴 Desafio
- Proteção de Rotas:
Imagine que você tem uma página
/adminque só pode ser acessada se o usuário estiver logado.- Como você usaria o
useNavigatedentro de umuseEffectpara redirecionar o usuário para a página de/logincaso ele não tenha um token salvo nolocalStorage? - O que acontece se o usuário clicar no botão "Voltar" do navegador após ser redirecionado?
- Como você usaria o
Exercícios 16 - Planejamento do Projeto Final 🏆
🟢 Fáceis
- Escolha do Tema: Qual dos temas sugeridos (Tarefa Cloud, E-commerce, Rede Social, Helpdesk) você escolheu para o seu projeto final? Se for um tema autoral, descreva-o em uma frase.
- Tecnologias: Enumere pelo menos 3 tecnologias do Frontend e 3 do Backend que você usará no seu TCC.
🟡 Médios
- Arquitetura: Desenhe um diagrama simples (ou explique em texto) como os dados fluirão da sua API Node.js até a tela do usuário no React.
- Segurança: Como você planeja proteger as informações sensíveis (senhas, segredos JWT) no seu projeto final?
- CORS: Por que você precisará configurar o CORS no seu servidor para que o projeto funcione?
🔴 Desafio
- Plano de Entrega:
Crie um cronograma de 3 passos para a construção do seu projeto:
- Passo 1: O que será feito primeiro no Backend?
- Passo 2: Como será a integração inicial?
- Passo 3: Qual a funcionalidade de "brilho" (extra) que você quer adicionar?
Projetos
Projetos Práticos 🚀
Transforme teoria em prática com desafios progressivos que compõem seu portfólio.
-
Módulo 1: Fundamentos de Backend ---
-
Módulo 2: Manipulação de Dados ---
-
Módulo 3: Segurança e Autenticação ---
-
Módulo 4: Aplicações SPA (React) ---
Projeto 01 - Cinto de Utilidades Backend 🛠️
Objetivo: Validar a instalação das ferramentas e testar a comunicação básica com uma API pública.
O Desafio
- Instale o Postman ou Insomnia.
- Realize uma requisição do tipo
GETpara a API pública do GitHub:https://api.github.com/users/github. - Analise a resposta (JSON). Identifique os campos
login,idepublic_repos. - Instale o Docker Desktop e rode o comando
docker run hello-worldno terminal para garantir que a virtualização está ativa. - Crie uma conta no GitHub (se não tiver) e instale o Git.
O que entregar?
- Print (screenshot) da resposta JSON no Postman/Insomnia.
- Print do terminal com a mensagem de sucesso do Docker "Hello from Docker!".
Projeto 02 - Modelagem de Fluxo de Gateway 🏗️
Objetivo: Entender o roteamento e a agregação de dados em um Gateway.
O Desafio
Imagine que você tem dois serviços:
- Serviço A (User): Retorna { "id": 1, "nome": "Ricardo" }
- Serviço B (Orders): Retorna [ { "id": 101, "valor": 50.0 }, { "id": 102, "valor": 30.0 } ]
- Desenhe um diagrama (pode ser no Mermaid ou papel) onde um API Gateway recebe uma chamada em
/dashboard/1e busca os dados nos dois serviços. - Escreva o JSON final que o Gateway entregaria para o Frontend, unindo as informações do usuário e seus pedidos.
- Pesquisa: Liste 3 ferramentas famosas de API Gateway de mercado (ex: Kong, AWS API Gateway, etc).
O que entregar?
- O diagrama de fluxo.
- O JSON de resposta agregada.
- A lista de ferramentas pesquisadas.
Projeto 03 - Contrato de API de Rede Social ⚡
Objetivo: Aplicar os conceitos de recursos, verbos e JSON na modelagem de uma rede social.
O Desafio
Você deve projetar a API para o recurso "Postagens" (Posts).
- Liste as 5 rotas principais (CRUD) para gerenciar postagens, indicando o Verbo, a URI e o Status Code de sucesso esperado.
- Crie um exemplo de JSON para uma postagem que contenha:
idautor_idconteúdo(texto)data_publicacaotags(lista de strings)
- Simulação de Erro: Qual seria a URI e o Verbo para dar um "Like" em uma postagem? Projete isso.
O que entregar?
- Tabela com as 5 rotas (Verbo, URI, Status).
- Bloco de código com o JSON de exemplo.
- Proposta da rota de "Like".
Projeto 04 - Criando o Primeiro Mock 🧱
Objetivo: Dominar o fluxo de documentação de contrato e simulação de servidor.
O Desafio
Você deve criar um servidor de Mock para uma API de Lista de Tarefas (ToDo).
- Use o Postman (Mock Server) ou o Mockoon para criar 2 rotas:
GET /tarefas: Deve retornar uma lista com pelo menos 3 tarefas.POST /tarefas: Deve aceitar uma nova tarefa e retornar201 Created.
- Documente os campos de uma tarefa (ex:
id,titulo,concluida). - Teste as rotas e garanta que o servidor responda corretamente no formato JSON.
O que entregar?
- Print (screenshot) do Swagger UI ou da tela do Mock Server rodando.
- O JSON de exemplo retornado pelo
GET /tarefas. - Print do teste da rota
POST /tarefascom sucesso.
Projeto 05 - Meu Primeiro Controller ⚙️
Objetivo: Praticar a criação de rotas e a captura de diferentes tipos de parâmetros.
O Desafio
Crie a estrutura de um Controller para um sistema de Gestão de Tarefas (To-Do). Você deve definir (em pseudocódigo ou na linguagem que preferir):
- Uma rota para listar todas as tarefas, permitindo um filtro opcional por
status(ex: concluída ou pendente). - Uma rota para buscar uma única tarefa pelo seu
id. - Uma rota para criar uma tarefa, recebendo
tituloedescricao. - Sinalize qual seria o Status Code de sucesso para cada uma das rotas acima.
O que avaliar?
- Uso correto de Path Params vs Query Params.
- Escolha dos verbos HTTP adequados.
- Padronização das respostas de sucesso.
Projeto 06 - Implementando a Lógica de Negócio 🧠
Objetivo: Aplicar a separação de camadas criando um Service para validação de dados.
O Desafio
Você deve criar o UsuarioService para um sistema de cadastro.
- Função
validarSenha(senha): Deve garantir que a senha tenha no mínimo 8 caracteres e contenha pelo menos um número. - Função
criarUsuario(dados):- Chama a validação de senha.
- Verifica se o e-mail já está sendo usado (simule um erro se estiver).
- Retorna o usuário criado (sem a senha!).
- Simule o Controller chamando esse Service e tratando o erro de "Senha Insegura" com um Status Code 400.
O que observar?
- O Service não deve usar objetos globais como
reqoures. - As mensagens de erro devem ser claras e informativas.
- Uso de DTOs (retornar objeto filtrado).
Projeto 07 - Modelagem de Banco de Dados 🗄️
Objetivo: Praticar a criação de esquemas relacionais e comandos SQL básicos.
O Desafio
Modele o banco de dados para um sistema de Aluguel de Filmes:
- Tabelas: Crie as tabelas
ClienteseFilmes. - Campos:
Clientesdeve terid,nomeeemail.Filmesdeve terid,tituloegenero.
- Relacionamento: Crie uma terceira tabela
Alugueisque ligue um cliente a um filme (incluindo adata_aluguel). - SQL: Escreva uma query que liste o nome do cliente e o título do filme para todos os aluguéis feitos hoje.
O que avaliar?
- Definição correta das Chaves Primárias.
- Uso de Chaves Estrangeiras para conectar as tabelas.
- Clareza na estrutura das colunas.
Projeto 08 - Schema de Validação Profissional ✅
Objetivo: Praticar a criação de regras de validação para garantir a integridade da API.
O Desafio
Crie o esquema de validação (em pseudocódigo ou usando uma biblioteca como Zod/Joi) para um Cadastro de Eventos:
- Campos Obrigatórios:
titulo(mín. 10 char),data(deve ser futura),capacidade_maxima(número positivo). - Campos Opcionais:
descricao(máx. 500 char),link_inscricao(formato de URL). - Sanitização: O título não deve conter espaços em branco sobrando no início ou no fim (trim).
- Simulação: Mostre qual seria a mensagem de erro retornada se o usuário enviasse uma capacidade negativa.
O que avaliar?
- Clareza e rigor das regras de validação.
- Escolha dos tipos de dados corretos.
- Mensagens de erro amigáveis ao desenvolvedor (DX).
Projeto 09 - Sistema de Login (Simulado) 🔐
Objetivo: Implementar a lógica de geração de tokens JWT para autenticação.
O Desafio
Crie uma API de simulação de login:
- Entrada: Receba um JSON com
emailesenha. - Validação: Verifique se a senha tem mais de 6 caracteres.
- JWT: Use uma biblioteca (ou pseudocódigo) para gerar um token que contenha o
iddo usuário e suapermissão(ex: 'aluno'). - Expiração: Configure o token para ser válido por apenas 24 horas.
- Resposta: Retorne para o cliente um objeto contendo o
tokene onomedo usuário.
O que avaliar?
- Tratamento correto de erro caso a senha seja curta.
- Estrutura limpa do Payload do JWT.
- Escolha de uma chave secreta segura (simulada).
Projeto 10 - Gerenciador de Permissões 🛡️
Objetivo: Implementar a lógica de proteção de rotas baseada em perfis de usuário.
O Desafio
Crie a estrutura de autorização para um Sistema de RH:
- Roles: Defina três tipos:
ADMIN,GESTOReFUNCIONARIO. - Regras:
- Todos podem ver o próprio perfil (
GET /me). - Apenas
GESTOReADMINpodem ver a lista de salários (GET /salarios). - Apenas
ADMINpode deletar um registro (DELETE /colaboradores/:id).
- Todos podem ver o próprio perfil (
- Middleware: Desenhe (em desenho técnico ou código) como seria o "fluxo da cancela" (Authentication Middleware -> Authorization Middleware).
O que avaliar?
- Separação clara entre quem é você e o que você pode fazer.
- Uso correto dos Status Codes em caso de bloqueio.
- Lógica de hierarquia (Admin pode tudo).
Projeto 11 - Blindagem de API 🏗️
Objetivo: Implementar camadas avançadas de segurança e renovação de tokens.
O Desafio
Fortaleça sua API de login:
- Helmet: Instale e configure o Helmet para proteger os Headers.
- CORS: Restrinja o acesso à API para que apenas o domínio
http://localhost:3000possa consultá-la. - Refresh Token: Implemente uma rota
/refreshque receba um refresh token, valide-o no banco (ou lista em memória) e gere um novoaccessToken. - Rate Limit: Adicione uma trava para que ninguém possa tentar logar mais de 5 vezes em 1 minuto.
O que avaliar?
- Configuração correta das origens no CORS.
- Lógica de expiração do Refresh Token (ele deve durar muito mais que o Access Token).
- Verificação se o Helmet está realmente escondendo o header
X-Powered-By.
Projeto 12 - Primeiro App React ⚛️
Objetivo: Criar e organizar componentes básicos usando React e Vite.
O Desafio
Crie uma página de Perfil de Usuário:
- Componente
FotoPerfil: Exibe uma imagem circular. - Componente
InfoUsuario: Recebenomeebiovia props e exibe na tela. - Componente
BotaoSeguir: Um botão simples que, por enquanto, apenas exibe um alerta ao ser clicado. - Layout: Organize esses componentes dentro do
App.jsxusando CSS simples para centralizar o conteúdo.
O que avaliar?
- Separação correta dos componentes em arquivos diferentes (ou funções separadas).
- Uso correto de Props para personalizar o nome do usuário.
- Sintaxe JSX correta (tags fechadas, className, etc).
Projeto 13 - Lista Dinâmica de Contatos 📱
Objetivo: Aplicar o uso de useState e gerenciamento de listas.
O Desafio
Crie um mini-gerenciador de contatos:
- Inputs: Dois campos de texto (Nome e Telefone).
- Botão Adicionar: Quando clicado, deve validar se os campos estão preenchidos e adicionar o contato em um Estado de Array.
- Lista: Exiba todos os contatos adicionados abaixo do formulário.
- Botão Limpar: Um botão que limpa toda a lista de contatos.
O que avaliar?
- Uso correto do
useStatepara os inputs e para a lista. - Uso do
.map()para renderizar a lista de contatos. - Limpeza dos campos de input após a adição com sucesso.
Projeto 14 - Buscador de Repositórios 🔍
Objetivo: Consumir uma API real e gerenciar estados de carregamento.
O Desafio
Crie um app que busca repositórios do GitHub de um usuário:
- Input: Campo para digitar o nome do usuário do GitHub.
- Botão Buscar: Ao clicar, deve disparar a busca.
- Loading: Enquanto a API não responde, deve aparecer o texto "Buscando repositórios...".
- Lista: Exiba o nome de todos os repositórios públicos encontrados.
- Erro: Se o usuário não existir, exiba "Erro: Usuário não encontrado".
O que avaliar?
- Uso do
useEffectpara carregar dados (pode ser ao carregar a página ou via clique). - Tratamento correto dos estados:
null,loading,dataeerror. - Renderização limpa usando
.map().
Projeto 15 - Sistema de Multi-Páginas 🚦
Objetivo: Implementar a navegação completa em uma SPA.
O Desafio
Transforme seu app de repositórios ou contatos em um site completo com 3 páginas:
- Home (/): Uma página de boas-vindas com links para as outras seções.
- Dashboard (/app): Onde fica a funcionalidade principal (ex: a busca de repositórios).
- Sobre (/sobre): Uma página contando quem criou o projeto.
- 404: Uma página personalizada para links quebrados.
Requisito Extra (Parâmetro)
Crie uma página de Perfil de Repositório (/repo/:id) que deve ser aberta ao clicar em um item da lista. Essa página só precisa exibir o ID que foi clicado por enquanto.
O que avaliar?
- Configuração correta do
BrowserRouternomain.jsxouApp.jsx. - Uso exclusivo de
<Link>para navegação em menus. - Funcionamento correto dos parâmetros de URL com
useParams.
Projeto 16 - App Final Full-Stack Integrador 🏆
Objetivo: O "TCC (Trabalho de Conclusão de Curso)" do desenvolvedor Full-Stack.
O Tema
Escolha um tema que resolva um problema real integrando o que você construiu no Backend (Módulos 1-3) com o que aprendeu no Frontend (Módulo 4).
Requisitos Mínimos
- Backend (Express): Uso obrigatório de rotas protegidas por JWT e validação de dados.
- Frontend (React): Componentização clara, uso de Hooks (
useState,useEffect) e navegação comReact Router. - Integração: O Frontend deve consumir a sua própria API de forma assíncrona.
- UX/UI: Interface amigável, com tratamento de estados de carregamento e erro.
- Segurança: Configuração correta de CORS e Headers de segurança (Helmet).
Documentação ✨
Seu repositório no GitHub deve ter um README.md impecável, com imagens (prints) da aplicação, explicação das tecnologias usadas e instruções claras de como rodar o servidor e o cliente. Este projeto será o seu maior cartão de visitas!
Boa sorte e bom código! 🚀🚀🚀
Quizzes
Quizzes Interativos 🧠
Teste seus conhecimentos rapidamente ao final de cada módulo.
-
Fase 1 ---
-
Fase 2 ---
-
Fase 3 ---
-
Fase 4 ---
Quiz 01 - Introdução
Quiz 02 - Introdução
Quiz 03 - Introdução
Quiz 04 - Introdução
Quiz 05 - Introdução
Quiz 06 - Introdução
Quiz 07 - Introdução
Quiz 08 - Introdução
Quiz 09 - Introdução
Quiz 10 - Introdução
Quiz 11 - Introdução
Quiz 12 - Introdução
Quiz 13 - Introdução
Quiz 14 - Introdução
Quiz 15 - Introdução
Quiz 16 - Introdução
Slides
Slides 📺
Material visual para acompanhamento das vídeo-aulas.
-
Módulo 1 ---
-
Módulo 2 ---
-
Módulo 3 ---
-
Módulo 4 ---
Aula 01 - Introdução a Microsserviços 🌐
De Monólitos a Sistemas Distribuídos
Agenda de Hoje 📅
- Panorama do Software Moderno
- Monólitos vs Microsserviços
- A Economia das APIs
- Escalabilidade Vertical vs Horizontal
- Cinto de Utilidades (Ferramentas)
- Setup do Ambiente
1. O Mundo Cloud-Native ☁️
- Sistemas globais exigem disponibilidade 24/7.
- Milhões de requisições por segundo.
- Deploy contínuo (várias vezes ao dia).
2. A Evolução da Arquitetura 🏛️➡️🏗️
2.1 O Monólito 🏛️
- Um único projeto, um único deploy.
- Tudo ou nada: erro em um lugar afeta tudo.
- Difícil de escalar partes específicas.
- Ideal para: Projetos pequenos, MVPs rápidos.
2.2 Microsserviços 🏗️
- Conjunto de serviços independentes.
- Comunicação via rede (APIs).
- Cada um com seu banco de dados.
- Ideal para: Sistemas complexos e escaláveis.
3. O Papel das APIs 📡
- Contract-First: Acordo de comunicação.
- REST como padrão dominante.
- JSON: A língua universal.
Escalabilidade: Vertical vs Horizontal
| Vertical (Scale Up) | Horizontal (Scale Out) |
|---|---|
| Aumenta CPU/RAM | Adiciona mais servidores |
| Tem limite físico | Virtualmente ilimitada |
| Causa downtime no upgrade | Zero downtime (Redundância) |
Arquitetura de Microsserviços
graph LR
User[Cliente] --> AGW[API Gateway]
AGW --> S1[Usuários]
AGW --> S2[Pedidos]
AGW --> S3[Pagamentos]
S1 --> DB1[(DB)]
S2 --> DB2[(DB)]
S3 --> DB3[(DB)]
4. Ferramentas Indispensáveis 🛠️
Client HTTP: Postman & Insomnia
- Testar rotas sem Frontend.
- Analisar Headers e Status Codes.
- Simular diferentes cenários de erro.
Containerização: Docker 🐋
- "Roda na minha máquina, roda em qualquer lugar".
- Isola dependências e versões.
- Facilita a subida de múltiplos serviços locais.
5. Estrutura de Projeto Backend 📂
- Divisão clara de responsabilidades.
- Controllers, Services e Repositories.
- Tratamento global de exceções.
6. Setup do Ambiente 🚀
Requisitos:
- IDE: VS Code ou IntelliJ.
- Postman (Desktop ou Extensão).
- Docker Desktop.
- Git & GitHub.
Resumo da Aula ✅
- Microsserviços trazem resiliência e escala.
- APIs são o coração da comunicação moderna.
- Ferramentas como Docker mudaram o jogo.
- Começamos nossa jornada Fullstack!
Próxima Aula: Arquitetura e Gateway 🏗️
- Como os serviços conversam?
- O que é Service Discovery?
- Protegendo a porta de entrada.
Dúvidas? 🤔
"A arquitetura de hoje é o legado de amanhã. Escolha com sabedoria."
Aula 02 - Arquitetura e Gateway 🏗️
Orquestrando Microsserviços
Agenda 📅
- Comunicação entre Serviços
- Síncrono vs Assíncrono
- O Papel do API Gateway
- Service Discovery
- Load Balancing
- Padrões de Resiliência
1. Como os Serviços Conversam? 💬
- Microsserviços são ilhas que precisam de pontes.
- Dois mundos: Sync e Async.
1.1 Comunicação Síncrona 🔄
- Cliente bloqueia até a resposta.
- Uso de HTTP/REST ou gRPC.
- Risco: Acoplamento temporal e gargalos.
1.2 Comunicação Assíncrona 📬
- Envia e esquece (Eventos).
- Uso de Filas e Tópicos (Broker).
- Vantagem: Escalabilidade e desacoplamento.
2. API Gateway: O Porteiro 🚪
- Única entrada para o mundo exterior.
- Esconde a complexidade interna.
Gateway Responsibilities
- Roteamento:
/p-> Pagamento,/e-> Estoque. - Segurança: Autenticação centralizada.
- Rate Limit: Proteção contra flood.
- Logs & Monitoramento.
3. Service Discovery 🔎
- Onde está o servidor de pagamentos?
- Agenda dinâmica de IPs e Portas.
- Ferramentas: Netflix Eureka, Consul.
4. Load Balancing ⚖️
- Distribuição inteligente da carga.
- Evita que um container "morra" de trabalho.
graph TD
GW[Gateway] --> LB[Load Balancer]
LB --> S1[Serviço A]
LB --> S2[Serviço B]
LB --> S3[Serviço C]
5. Resiliência: Circuit Breaker 🔌
- Detecta serviços lentos ou falhos.
- Abre o circuito para proteger o resto do sistema.
- Evita o cascateamento de erros.
Comparativo: Sync vs Async
| Característica | Síncrono 🔄 | Assíncrono 📬 |
|---|---|---|
| Resposta | Imediata | Eventual |
| Desempenho | Limitado pelo destino | Alto débito |
| Uso comum | Cadastro/Login | Geração de Relatórios |
6. Prática: O "Dashboard" Agregador 💻
- Como o Gateway une dados de 3 serviços?
- Agregação de respostas (Aggregation Pattern).
Desafio Relâmpago ⚡
O que acontece se o seu API Gateway cair? Ele é um ponto único de falha?
Resumo ✅
- Sync é fácil, Async é escalável.
- API Gateway protege e organiza.
- Service Discovery é essencial em containers.
- Resiliência não é opcional!
Próxima Aula: Modelagem REST 📡
- Verbos HTTP.
- Status Codes.
- O contrato ideal.
Dúvidas? 🏗️
Aula 03 - Modelagem de APIs RESTful 📡
Recursos, Verbos e Contratos
Agenda 📅
- O que é REST?
- Recursos e URIs
- Verbos HTTP (GET, POST, PUT...)
- Status Codes
- JSON: A Linguagem das APIs
- Boas Práticas de Design
1. REST: A "Língua" da Web 🌐
- Style arquitetural para sistemas distribuídos.
- Baseado no protocolo HTTP.
- Independência entre Client e Server.
Princípios REST
- Stateless: Cada requisição é única.
- Uniform Interface: Padrões compartilhados.
- Cacheable: Melhore a performance.
2. Identificando Recursos 📍
- Um recurso é qualquer coisa que expomos.
- URI: O endereço do recurso.
O que NÃO fazer:
GET /obterUsuarios ❌
O que fazer:
GET /usuarios ✅ (Sempre substantivos no plural!)
3. Os Verbos HTTP 🛠️
Eles definem a intenção da chamada:
- GET: Buscar dados.
- POST: Criar novo dado.
- PUT: Atualizar (Trocar tudo).
- PATCH: Atualizar (Apenas um pedaço).
- DELETE: Remover dado.
Idempotência e Segurança
| Verbo | Seguro? | Idempotente? |
|---|---|---|
| GET | Sim ✅ | Sim ✅ |
| POST | Não ❌ | Não ❌ |
| PUT | Não ❌ | Sim ✅ |
| DELETE | Não ❌ | Sim ✅ |
4. Status Codes: A Resposta 🚦
- 2xx: Deu certo! (200, 201, 204).
- 4xx: Você (cliente) errou algo (400, 401, 404).
- 5xx: Eu (servidor) quebrei (500, 503).
5. O Formato JSON 🏗️
- Leve, legível e universal.
6. Design de URIs Complexas
Como buscar os pedidos de um usuário específico?
GET /usuarios/123/pedidos ✅
- Hierarquia lógica e limpa.
7. Prática: Postman em Ação 💻
- Testando verbos em APIs reais.
- Analisando Headers e Body.
Desafio REST ⚡
Se você quer mudar apenas o e-mail de um usuário, qual verbo deve usar: PUT ou PATCH?
Resumo ✅
- REST é sobre recursos e padrões.
- URIs usam substantivos no plural.
- Status codes guiam o frontend.
- JSON é o padrão de facto.
Próxima Aula: Swagger e Mocks 📝
- Documentação automática.
- Como trabalhar sem o backend pronto?
Dúvidas? 📡
Aula 04 - Documentação e Mocks 📝
Developer Experience e Contratos
Agenda 📅
- Por que documentar?
- OpenAPI vs Swagger
- Swagger UI e Editor
- O Poder dos Mocks
- Developer Experience (DX)
- Ferramentas de Simulação
1. Documentação é DX 🚀
- Sua API é seu produto.
- Documentar economiza tempo de suporte.
- Facilita a integração com Front/Mobile.
2. OpenAPI (OAS) 📜
- O padrão mundial.
- Arquivo YAML ou JSON descritivo.
- Agnóstico de linguagem.
3. Swagger: O Canivete Suíço 🛠️
- Editor: Escreva e valide o contrato.
- UI: Gere a página visual de testes.
- Codegen: Gere código (client/server) automaticamente.
Swagger UI em Ação
- Permite testar endpoints no próprio navegador.
- Mostra exemplos de JSON de entrada e saída.
- Exibe todos os Status Codes possíveis.
4. O Poder dos Mocks 🎭
- Development in Parallel: Front não espera pelo Back.
- Servidor "Fake" que retorna dados reais.
- Valide a experiência antes da implementação complexa.
5. Developer Experience (DX) 👨💻
Como ser amado por outros devs:
- Nomes de rotas claros.
- Erros descritivos no Body.
- Exemplos de requisição.
- Documentação atualizada (ou gerada pelo código).
6. Ferramentas Recomendadas 🧰
- Swagger Editor: Online ou Local.
- Mockoon: Mock local amigável.
- Prism: Mock via CLI.
- Postman: Collections documentadas.
7. Prática: Editando um YAML 💻
- Desenhando um endpoint
GET /tarefas. - Definindo parâmetros de entrada.
- Criando esquemas de dados.
Desafio: Mock vs Stubs ⚡
Qual a principal vantagem de um Mock Server online (como Postman) em relação a um Mock rodando apenas no computador do desenvolvedor?
Resumo ✅
- OpenAPI é o contrato.
- Swagger UI é a vitrine da sua API.
- Mocks destravam o desenvolvimento da equipe.
- DX é o diferencial de uma boa API.
Próxima Aula: Implementação Backend! 💻
Módulo 2: Manipulação de Dados
- Controllers e Services.
- Repositories e Banco de Dados.
- Mão na massa com código real!
Dúvidas? 📝
Aula 05 - Implementação de APIs ⚙️
Controllers e Rotas
Agenda 📅
- Camadas do Backend
- O Papel do Controller
- Rotas e Handlers
- Capturando Dados (Params/Body)
- Status Codes na Prática
- Injeção de Dependência
1. Organização em Camadas 🧱
- Controller: Trata a entrada (HTTP).
- Service: Regras de negócio.
- Repository: Acesso ao banco.
2. O Papel do Controller 🎮
- Ele é o ponto de entrada.
- Não deve ter lógica complexa!
- Deve apenas orquestrar a execução.
Controller = Garçom 🤵 Service = Cozinheiro 👨🍳
3. Rotas e Handlers 📍
- Rota: Verbo HTTP + Path.
- Handler: Função executada.
4. Capturando Dados 📥
- Path Params:
/id/123(Identificação). - Query Params:
?q=busca(Filtro). - Body: Enviando JSON (Criação/Update).
5. Respostas de Qualidade 📤
- Nunca esqueça o Status Code!
- Sucesso: 200, 201, 204.
- Erro: 400, 401, 404, 500.
6. Injeção de Dependência 💉
- Receber serviços prontos.
- Facilita testar o Controller "isolado".
7. Prática: O Primeiro Endpoint 💻
- Mapeando um
GET /ping. - Retornando um
pongem JSON. - Testando no Insomnia/Postman.
Desafio: Params vs Query ⚡
Se você quer listar todos os alunos de uma sala com o nome "Pedro", qual tipo de parâmetro você usaria para o nome?
Resumo ✅
- Controllers são a porta de entrada.
- Devem ser leves e objetivos.
- Capturam dados e retornam status/JSON.
- Seguem as rotas definidas.
Próxima Aula: Regras de Negócio! 🧠
Services e Validações
- Onde o cálculo acontece.
- Isolando o código do "mundo externo".
Dúvidas? ⚙️
Aula 06 - Services e Regras de Negócio 🧠
O Cérebro da Aplicação
Agenda 📅
- Por que separar as coisas?
- Responsabilidades do Service
- O Fluxo: Controller -> Service
- Tratamento de Erros Profissional
- DTOs: Protegendo os Dados
- Service vs ViewModel (Mobile)
1. O Problema: "Controller Gordo" 🍔
- Lógica de negócio misturada com HTTP.
- Código impossível de reutilizar.
- Difícil de testar.
2. A Solução: Layered Architecture 🧱
- Controller: Trata o transporte (HTTP).
- Service: Trata a regra (O QUE fazer).
3. O que vai no Service? ⚖️
- Validações complexas.
- Cálculos de valores.
- Envio de e-mails/notificações.
- Integração com repositórios.
4. Tratamento de Erros ⚠️
- O Service Lança (Throws).
- O Controller Captura (Catches).
// Service
if (!saldo) throw new Error("Saldo Insuficiente");
// Controller
try { ... } catch (e) { res.status(400)... }
5. DTOs: Filtrando a Saída 📦
- Nunca envie "tudo" do banco para o cliente.
- Proteja campos sensíveis (Ex:
senha_hash). - Melhore a performance (menos dados trafegados).
6. Service vs ViewModel 🆚
- No Backend: Service é o cérebro.
- No Mobile/Front: ViewModel é o cérebro.
- Ambos servem para "limpar" a camada de visualização.
7. Prática: Validando um Cadastro 💻
- Verificando se o e-mail é válido.
- Verificando se o usuário já existe.
- Lançando erros específicos.
Desafio: Onde colocar? ⚡
Se uma regra diz: "Usuários VIP ganham 20% de desconto", essa regra deve ficar no Controller ou no Service?
Resumo ✅
- Controllers recebem, Services processam.
- Mantenha seus Controllers "finos" (Slim Controllers).
- Centralize as regras para facilitar a manutenção.
- DTOs são as fronteiras dos dados.
Próxima Aula: Onde os dados vivem! 🗄️
Repositories e Banco de Dados
- PostgreSQL e SQL básico.
- Camada de persistência.
Dúvidas? 🧠
Aula 07 - Repositories e Banco de Dados 🗄️
Onde a informação descansa
Agenda 📅
- Por que Bancos de Dados?
- PostgreSQL: O Robusto
- SQL Básico (SELECT, INSERT...)
- Relacionamentos (1:N, N:N)
- Camada de Persistence
- O Padrão Repository
1. Persistência de Dados 💾
- Sem banco, o servidor esquece tudo ao reiniciar.
- Precisamos de segurança e integridade.
- Estritamente Tipado: O banco garante o formato.
2. Por que PostgreSQL? 🐘
- Código Aberto (Open Source).
- Extremamente confiável (ACID).
- Suporta dados complexos (JSONB).
3. SQL: A Linguagem Universal 🗣️
- DDL: Define a estrutura (Tabelas).
- DML: Manipula os dados (Linhas).
4. O Coração: Relacionamentos 🔗
- 1:N: Um cliente, muitos pedidos.
- N:N: Muitos alunos, muitos cursos.
- Foreign Key: A âncora que liga tudo.
5. Camada de Persistence 🧱
- O código que conversa com o driver do banco.
- Onde as queries são traduzidas para o código.
6. Padrão Repository 📥
- "Não me diga como, diga O QUE você quer".
- Isola o SQL da regra de negócio.
7. Migrations 📜
- Controle de versão para o Banco.
- Permite "voltar no tempo" se algo quebrar.
- Mantém o time em sincronia.
Desafio SQL ⚡
Qual comando você usaria para mudar o preço de todos os produtos da categoria 'Games' para 99.90?
Resumo ✅
- Bancos de dados dão memória ao sistema.
- PostgreSQL é o padrão da indústria.
- SQL é habilidade obrigatória para backend.
- Repository Pattern traz flexibilidade.
Próxima Aula: Integridade! ✅
Validação e Boas Práticas
- Garantindo que dados "sujos" não entrem no banco.
- Tratamento de exceções de banco.
Dúvidas? 🗄️
Aula 08 - Boas Práticas e Validação ✅
Qualidade e Segurança no Backend
Agenda 📅
- Por que Validar Tudo?
- Validação vs Sanitização
- Schema Validation (Ex: Zod)
- Clean Code (Código Limpo)
- Tratamento de Erros Profissional
- Middlewares Globais
1. Regra de Ouro: Desconfiança 🛡️
- O cliente é o "lado perigoso" da aplicação.
- Validações evitam dados corrompidos.
- Defesa em Profundidade: Garanta a regra no banco E no código.
2. Validar vs Sanitizar 🧼
- Validar: Checar (Idade > 18?).
- Sanitizar: Limpar (Remover
<script>).
3. Schema Validation 📐
- Crie "moldes" para seus dados.
- Validação centralizada e reutilizável.
4. O Backend Elegante (Clean Code) ✨
- DRY: Don't Repeat Yourself (Não repita lógica).
- KISS: Keep It Simple, Stupid (Mantenha o simples).
- Nomes de funções que explicam o que está acontecendo.
5. Tratamento de Erros 🚨
- Controller trata o fluxo, não o detalhe técnico.
- Try/Catch Global: Evite crashes.
- Mensagens amigáveis para o cliente.
6. Logs vs Mensagens 📜
- Terminal/Log: Detalhe técnico completo.
- Cliente (JSON): Apenas o que ele precisa saber.
"Ocorreu um erro interno" (Cliente) ✅ "Query failed at line 42 due to NULL constraint" (Logs) ✅
7. Prática: O Schema Perfeito 💻
- Validando um produto complexo.
- Tratando erros de tipo (String no lugar de Number).
Desafio: Limpeza ⚡
Se você recebe um texto de um post com muitos espaços em branco no final, você deve Validar ou Sanitizar?
Resumo ✅
- Backend robusto exige validação rigorosa.
- Limpe os dados antes de salvar (Sanitize).
- Middleware Global centraliza a gestão de falhas.
- Código limpo economiza meses de manutenção.
Próxima Aula: Módulo 3! 🔐
Segurança e Autenticação
- Quem é você? (Authentication).
- O que você pode fazer? (Authorization).
Dúvidas? ✅
Aula 09 - Segurança e Autenticação com JWT 🔐
Portas trancadas e Crachás Digitais
Agenda 📅
- Autenticação vs Autorização
- O Fim das Sessões (Stateful)
- O que é JWT?
- Estrutura: Header, Payload, Signature
- Fluxo de Login completo
- Melhores Práticas de Segurança
1. Quem é Você? (Autenticação) 🚦
- Validar a identidade do usuário.
- Login e Senha.
- Autorização: O que você PODE fazer? (Níveis de acesso).
2. Por que JWT? 🤔
- Abordagem Stateless (Sem estado).
- O servidor não guarda sessão na memória (escalável!).
- Perfeito para Microserviços e Mobile.
3. Estrutura do Token 🎫
- Header: Algoritmo (ex: HS256).
- Payload: Os dados (id, role, nome).
- Signature: O lacre de segurança.
4. O Coração do JWT: A Assinatura 🖋️
- Usa uma
SECRET_KEYno servidor. - Garante que o token não foi "hackeado" ou alterado.
5. Fluxo de Login 🌊
- Envia credenciais -> 2. Servidor valida -> 3. Gera JWT -> 4. Frontend guarda o Token -> 5. Envia no Header em cada requisição.
6. Segurança em Mobile 📱
- Nunca guarde em arquivos de texto!
- Use EncryptedSharedPreferences (Android) ou Keychain (iOS).
7. Melhores Práticas 🏆
- Use chaves secretas longas e seguras.
- Defina tempo de expiração (
expiresIn). - Protocolo HTTPS é obrigatório!
Desafio de Segurança ⚡
O Payload do JWT é criptografado ou apenas codificado? Posso guardar a senha do usuário lá?
Resumo ✅
- JWT permite autenticação rápida e escalável.
- Header + Payload + Signature.
- Stateless = Servidor mais leve.
Próxima Aula: Controle de Acesso 🛡️
Quem manda aqui? (RBAC)
- Middlewares de autorização.
- Protegendo rotas por nível de usuário.
Dúvidas? 🔐
Aula 10 - Controle de Acesso (RBAC) 🛡️
Hierarquia e Segurança em Camadas
Agenda 📅
- O que é RBAC? (Roles)
- Autenticação vs Autorização
- O Fluxo do Middleware
- Erros 401 vs 403
- Protegendo rotas na prática
- Hierarquia de Perfis
1. Role-Based Access Control 👑
- Permissões ligadas a Perfis (Roles).
- Ex: ADMIN, EDITOR, VIEWER.
- Facilita a gestão de milhares de usuários.
2. A Cancela (Middleware) 🚧
- O middleware checa se o usuário tem a "chave" certa.
- Se não tiver -> 403 Forbidden.
- Se tiver ->
next().
3. O Fluxo de Segurança 🌊
graph LR
Req[Request] --> Auth[Autenticação]
Auth --> |OK| Role[Autorização]
Role --> |OK| Controller[Recurso Final]
4. 401 vs 403: Não confunda! ❌
- 401 (Unauthorized): "Quem é você?". Token inválido ou ausente.
- 403 (Forbidden): "Eu sei quem você é, mas não deixo entrar". Falta de permissão.
5. Implementação Dinâmica 🔒
// Middleware genérico
router.delete('/usuario/:id',
autenticar,
autorizar(['ADMIN']),
userController.remover
);
6. Hierarquia de Acesso 🏛️
- Um Admin deve poder acessar rotas de User?
- Design de sistema: Roles "Pai" e "Filho".
7. Melhores Práticas 🏆
- Centralize a lógica em Middlewares.
- Nunca exponha permissões sensíveis no frontend (segurança do lado do servidor).
Desafio: Segurança ⚡
Em um sistema escolar, o Diretor e o Professor podem ver notas. O Aluno só vê as dele. Como você configuraria a Role da rota GET /notas?
Resumo ✅
- RBAC organiza permissões por grupos.
- Middlewares são os guardiões das rotas.
- Diferenciar 401 de 403 é vital para Debug.
Próxima Aula: Segurança Avançada 🏗️
Session vs Token e Refresh Tokens
- O que fazer quando o token expira?
- Protegendo contra ataques comuns (XSS, CSRF).
Dúvidas? 🛡️
Aula 11 - Refresh Token e Segurança Avançada 🏗️
Blindando sua API contra o mundo
Agenda 📅
- O Problema do Token Curto ⏰
- Refresh Tokens (O que são?)
- CORS: Origens e Destinos
- Helmet: Headers de Aço
- Rate Limit: Contra Brute Force
- Ataques Comuns (XSS, Injection)
1. Por que Tokens Expiram? ⏰
- Segurança! Se roubarem o token, ele dura pouco.
- Problema: O usuário odeia fazer login toda hora.
2. Refresh Token 🔁
- Um token de longa duração (7 dias+).
- Serve apenas para trocar por um novo Access Token.
- Deve ser invalidado se o usuário deslogar.
3. CORS: Cross-Origin Resource Sharing 🌍
- "Quem pode me chamar?".
- Resolvido via Headers no Servidor.
- Nunca use
origin: '*'em ambientes reais!
4. Helmet: Proteção de Headers 🪖
- Remove o
X-Powered-By(não diz que é Express). - Adiciona proteção contra Clickjacking e XSS.
5. Rate Limiting 🔨
- 5 tentativas de login por minuto? Sim.
- Evita que robôs tentem descobrir senhas via "força bruta".
6. Onde salvar os Tokens? 🛡️
- Frontend: LocalStorage? Seguro?
- Melhor Prática: Cookies
HttpOnly+Secure.
7. Melhores Práticas de Segurança 🏆
- Use HTTPS sempre.
- Valide TODAS as entradas do usuário.
- Mantenha as bibliotecas atualizadas.
Desafio de Segurança ⚡
Qual a diferença entre 401 e 403 no contexto de Refresh Tokens? Se eu recebo 401, eu tento o refresh ou deslogo o usuário?
Resumo ✅
- Refresh Token equilibra UX e Segurança.
- CORS e Helmet são as portas do seu castelo.
- Proteja-se contra robôs com Rate Limit.
Próximo Módulo: Front-End Moderno 🎨
Saindo das APIs e indo para a Web!
- Introdução ao React/Vite.
- Consumindo nossas APIs no navegador.
Dúvidas? 🏗️
Aula 12 - Introdução ao React ⚛️
O Poder dos Componentes Modernos
Agenda 📅
- O que são SPAs?
- Por que React?
- Vite: A Ferramenta Rápida
- JSX: JS + HTML
- Componentes e LEGO
- Props: O Coração Dinâmico
1. Single Page Applications (SPA) 📄
- O site que nunca recarrega.
- Navegação fluida e instantânea.
- Ex: Gmail, Facebook, Spotify Web.
2. Por que o React venceu? ⚔️
- Componentização (Foco no Reuso).
- Virtual DOM (Foco na Performance).
- Gigantesco Ecossistema (Foco no Emprego).
3. Vite: O Novo Padrão ⚡
- Inicia o projeto em segundos.
- Feedback instantâneo durante o código.
4. JSX: A Mistura Perfeita 🧪
- Parece HTML, mas tem o poder do Javascript.
5. Componentes = LEGO 🧩
- Pequenas partes isoladas.
- Facilita testes e trabalho em equipe.
6. Props: Passando o Bastão 🎁
- Permite que componentes recebam dados do "pai".
- Torna componentes genéricos e reutilizáveis.
Resumo ✅
- SPA torna a Web parecida com Apps.
- React organiza sua UI em componentes.
- Vite é seu melhor amigo no desenvolvimento.
Próxima Aula: Dinâmica e Estado 🎣
O que acontece quando o usuário clica?
- Hooks:
useState. - Reatividade na prática.
Dúvidas? ⚛️
Aula 13 - Estado e Hooks 🎣
Tornando seu App Interativo
Agenda 📅
- O que é o Estado (State)?
- Hook
useState - Lidando com Cliques e Eventos
- Inputs Controlados
- Imutabilidade e Arrays
1. O Problema da Estática 🧱
- Variáveis comuns mudam nos bastidores...
- ...mas a tela continua a mesma!
- O React precisa de um sinal para re-desenhar.
2. useState: O Motor de Mudança 🚀
- cont: O valor atual.
- setCont: A função que atualiza.
- 0: O ponto de partida.
3. Eventos no React ⚡
onClick={funcao}onChange={(e) => ...}- Sempre em CamelCase!
4. Inputs Controlados ⌨️
- O React é quem manda no valor do input.
value={estado}+onChange.- Facilita validação e limpeza de campos.
5. Imutabilidade (Muito Importante!) 💎
- Nunca altere o estado original:
lista.push(x)❌ - Sempre crie uma cópia nova:
setLista([...lista, x])✅
6. Fluxo de Dados 🌊
- O estado flui do Pai para o Filho via Props.
- Se o estado do Pai muda, todo mundo abaixo dele atualiza.
Desafio de Estado ⚡
Se eu tenho um botão que soma +1 ao contador, o que acontece com a interface se eu esquecer de importar o useState e usar uma variável global let contador = 0?
Resumo ✅
useStatetraz vida aos componentes.- Mudança de estado = Re-renderização.
- Use sempre funções disparadoras (
set...).
Próxima Aula: Efeitos e APIs 🌐
Buscando dados no mundo real!
- Hook:
useEffect. - Consumindo nossa API Backend.
Dúvidas? 🎣
Aula 14 - Efeitos e APIs 🌐
Conectando seu App ao Mundo Real
Agenda 📅
- O que são Side Effects?
- Hook
useEffect - O Array de Dependências
- Buscando dados com
fetch - Estados de Carregamento e Erro
1. Além da Interface 🧪
- Efeitos colaterais são ações que tocam o mundo externo ao componente.
- Ex: Buscar usuários, mudar o título da aba, iniciar um cronômetro.
2. useState vs useEffect 🥊
- useState: Para dados que o usuário vê mudando.
- useEffect: Para ações que o componente faz "sozinho".
3. Os 3 Momentos do useEffect 🕒
- Montagem: Quando o componente nasce.
- Atualização: Quando um dado monitorado muda.
- Desmontagem: Quando o componente morre (Cleanup).
4. O Array de Dependências [] 🗃️
[]-> Roda só uma vez.[cont]-> Roda sempre quecontmudar.Sem array-> Roda em toda atualização (Perigo!).
5. Chamadas de API (Fetch) 📨
useEffect(() => {
fetch("https://api...")
.then(res => res.json())
.then(data => setData(data));
}, []);
6. UX: Estados de Rede 🛡️
- Loading: Mostre um Spinner enquanto espera.
- Error: Avise se a internet caiu ou o usuário não existe.
- Empty: Diga se não há resultados.
Desafio de Efeito ⚡
Se você colocar um alert("Olá") dentro de um useEffect sem o array [], quantas vezes o alerta vai aparecer se o usuário ficar digitando em um campo de texto que atualiza o estado?
Resumo ✅
useEffectorganiza as ações assíncronas.- Controle quando rodar via array de dependências.
- Trate sempre o carregamento e erros para uma boa UX.
Próxima Aula: Navegação 🚦
Multi-páginas com React Router!
/home,/perfil,/contato.- Links e Navegação Programática.
Dúvidas? 🌐
Aula 15 - React Router 🚦
Criando Apps Multi-Página
Agenda 📅
- O que são SPAs?
- Multi-páginas (Simuladas)
- Componentes de Rota
- Navegação (
LinkeuseNavigate) - Parâmetros dinâmicos (
:id)
1. O Mundo do SPA ⚛️
- O site é uma única página HTML.
- O Javascript "troca" a tela sem recarregar.
- UX rápida e fluida.
2. React Router Dom ⚙️
- A biblioteca padrão para web.
- Permite que a URL combine com o que aparece na tela.
3. A Estrutura Básica 🏗️
- BrowserRouter: O container principal.
- Routes: O seletor de rotas.
- Route: Define o caminho (
path) e o componente (element).
4. Navegando sem Recarregar! 🏃♂️
- Use
<Link to="/contato"> - NUNCA use
<a href="...">para rotas internas.
5. Navegação Programática 🚀
- Ideal para redirecionar após ações (Login, Clique em Card).
6. Rotas Dinâmicas (URL Params) 🆔
path="/perfil/:username"- Hook
useParams()captura o valor. - Uma única página que se adapta a mil perfis.
7. Página 404 (Not Found) 👻
path="*"- Garante que o usuário nunca caia em uma tela em branco.
Desafio de Roteamento ⚡
Se eu digitar www.meusite.com/asdfg e não tiver uma rota configurada para isso, o que o usuário vai ver se eu NÃO colocar uma rota com o path="*"?
Resumo ✅
- Roteamento traz a sensação de um site real.
- Hooks
useNavigateeuseParamssão essenciais. - SPAs são o padrão da indústria moderna.
Próxima Aula: O Grande Final 🏆
Projeto Integrado: Backend + Frontend!
- Conectando nossa API Node ao site React.
- O Projeto Final do Curso!
Dúvidas? 🚦
Aula 16 - Projeto Final e Conclusão �
De aluno a Desenvolvedor Full-Stack
Agenda 📅
- O Desafio Final 🔗
- Requisitos Técnicos
- Portfólio no GitHub
- Onde continuar estudando?
- Mensagem de Encerramento
1. O Desafio Final 🚀
Você deve entregar um projeto integrado contendo: - Frontend: SPA em React com rotas. - Backend: API segura em Node.js. - Integração: Conexão real entre os dois. - Design: CSS moderno e responsivo.
2. Sugestões de Temas 💡
- Gerenciador de Tarefas �
- Mini E-commerce 🛒
- Rede Social Simplificada 💬
- Dashboard de Monitoramento 📊
3. O README de Elite ✨
- Prints ou Vídeos do site funcionando.
- Lista detalhada de tecnologias.
- Guia: "Como rodar o Projeto".
4. Onde ir agora? 📚
- TypeScript: Segurança de tipos.
- Bancos SQL: Postgres e MySQL.
- Next.js: O rei do mercado React.
- Docker: Infraestrutura moderna.
5. Soft Skills 🤝
- Não é só saber programar!
- Trabalho em equipe.
- Resolução de problemas reais.
6. O Mercado Full-Stack 📈
- Demanda altíssima por devs completos.
- Salários excelentes.
- Dashboards e Sistemas Web movem o mundo!
7. Mensagem Final 🌟
"Programar é a arte de criar soluções onde antes só havia problemas."
- Você construiu a base sólida.
- O código é sua ferramenta de transformação.
Parabéns pela Jornada! 🎓🚀
Vá e construa o futuro da Web.
Dúvidas Finais? 🤔
Configuração
Ambientes de Desenvolvimento 🛠️
Guias para configurar seu computador para o desenvolvimento mobile.
-
Android --- Instalação do Android Studio, SDK e emuladores.
-
iOS (Opcional/Referência) --- Configuração básica de Xcode e ferramentas Mac.
-
Ferramentas de Apoio --- Git, Terminais e Postman/Insomnia para testes de API.
Setup 01: Android Studio 🤖
O Android Studio é a IDE oficial para o desenvolvimento Android.
1. Requisitos de Sistema
- RAM: Mínimo 8GB (Sugerido 16GB+).
- Espaço: Mínimo 10GB para IDE + SDKs.
- Processador: Intel Core i5 ou equivalente.
2. Instalação
- Acesse o site oficial: developer.android.com/studio.
- Baixe a versão mais recente para o seu Sistema Operacional.
- Execute o instalador e escolha a opção "Standard" na configuração inicial.
3. Configurando o SDK
- Após a instalação, vá em Settings > Languages & Frameworks > Android SDK.
- Certifique-se de que a versão mais recente do Android (estável) esteja instalada.
- Na aba SDK Tools, instale o "Android Emulator" e o "Intel x86 Emulator Accelerator (HAXM)" se estiver no Windows com Intel.
4. Criando um Emulador (AVD)
- Abra o Device Manager.
- Clique em Create Device.
- Escolha um dispositivo (ex: Pixel 7).
- Selecione uma imagem de sistema (ex: Level 34 - Android 14).
- Finalize e clique no "Play" para iniciar o celular virtual.
5. Solução de Problemas ⚠️
- VT-x is disabled: Você precisa habilitar a virtualização na BIOS do seu computador.
- Studio muito lento: Adicione a pasta do projeto e as pastas do Android SDK nas exclusões do seu Antivírus.
Setup 02: Xcode (iOS Foundation) 🍎
O Xcode é a ferramenta necessária para compilar e testar apps iOS.
[!IMPORTANT] O Xcode requer um computador Mac (macOS).
1. Instalação
- Abra a App Store no seu Mac.
- Pesquise por Xcode.
- Clique em Obter/Instalar.
- Após o download, abra o Xcode para carregar os componentes adicionais do macOS.
2. Configurando Simuladores
- Vá em Settings > Platforms.
- Verifique se o componente "iOS" está baixado.
- Se não estiver, clique em "GET" para baixar a versão mais estável.
3. Comandos de Linha (CLI)
Para que ferramentas de automação funcionem, você precisa instalar os Command Line Tools:
4. Opcional: CocoaPods
Muitos projetos iOS antigos ainda usam CocoaPods para dependências:
5. Solução de Problemas ⚠️
- Espaço em Disco: O Xcode é muito grande. Garanta pelo menos 40GB de espaço livre para ele e os simuladores.
- Build Lento: Use simuladores de modelos mais simples (ex: iPhone SE) para poupar memória RAM se necessário.
Sobre
Sobre o Curso
🎓 APIs e Microsserviços Profissionais
Este curso foi projetado para capacitar desenvolvedores na criação de arquiteturas distribuídas modernas, focando na integração entre backends escaláveis e frontends dinâmicos do tipo SPA.
🎯 Objetivos do Curso
-
Arquitetura Distribuída --- Compreender a transição de monólitos para microsserviços e a importância da comunicação eficiente entre serviços.
-
Domínio de APIs REST --- Dominar a modelagem, implementação e documentação de APIs seguindo as melhores práticas do mercado.
-
Segurança Avançada --- Implementar sistemas de autenticação e autorização robustos utilizando JWT e controle de acesso baseado em perfis.
-
Frontend Moderno (SPA) --- Desenvolver interfaces ricas e reativas, conectando-as perfeitamente ao ecossistema de APIs backend.
📚 O Que Você Vai Aprender
Módulo 1 – Serviços e Microsserviços
- Conceitos de Microsserviços vs Monólitos
- Arquitetura e API Gateways
- Modelagem de APIs RESTful
- Documentação com Swagger e Mocks
Módulo 2 – Manipulação de Dados
- Implementação de Endpoints (Backend)
- Persistência com ORM e SQL
- Testes Unitários com Mocks
- Testes Integrados e Deploy
Módulo 3 – Autenticação e Segurança
- Estratégias Web (Cookies vs Tokens)
- Implementação de JWT
- Criptografia e Proteção de Rotas
- Autorização RBAC (Perfis)
Módulo 4 – Aplicações Web SPA
- Conceitos de SPA e Renderização
- Componentização e Templates
- Gerenciamento de Estados e Eventos
- Roteamento e Projeto Integrador
🛠️ Metodologia
Foco 100% prático e orientado a projetos. Cada módulo culmina em uma etapa funcional de um sistema completo, garantindo que ao final do curso você tenha um portfólio robusto de arquitetura fullstack.
Pronto para dominar o Backend? Começar Agora
Roadmap do Projeto: APIs e Microsserviços 🚀
Este documento rastreia a evolução do curso.
✅ Fase 1: Planejamento (Concluído)
- [x] Definição Syllabus (16 Aulas)
- [x] Estrutura Backend-first com integração SPA
- [x] Configuração MkDocs Material
✅ Fase 2: Conteúdo Base (Concluído)
- [x] Criação das 16 Aulas (Markdown)
- [x] Criação dos 16 Quizzes (HTML)
- [x] Criação dos 16 Conjuntos de Exercícios
- [x] Criação dos 16 Slides (RevealJS)
✅ Fase 3: Projetos e UX (Concluído)
- [x] Definição dos 16 Projetos práticos
- [x] Documentação Swagger/OpenAPI integrada
- [x] Diagramação Mermaid de arquitetura de serviços
🚀 Fase 4: Lançamento e Manutenção
- [x] Deploy GitHub Pages (GitHub Actions)
- [ ] Atualização para novas versões de frameworks (Spring/Node/React)
- [ ] Inclusão de exemplos de mensageria (RabbitMQ/Kafka)
Status Atual: Finalizado / Manutenção Última Atualização: 19/02/2026
Materiais Complementares 📚
Bem-vindo à seção de materiais complementares do curso de APIs e Microsserviços. Aqui você encontra recursos adicionais para apoiar seus estudos e aprofundar seu conhecimento técnico.
-
- Acompanhe o conteúdo teórico com slides dinâmicos.
-
- Pratique a implementação de microsserviços e rotas REST.
-
- Valide seu aprendizado com testes rápidos por módulo.
-
- Construa um ecossistema completo para seu portfólio.
-
- Guias de instalação (Docker, IDEs, Postman).
Versão para Impressão
Esta página foi gerada automaticamente para impressão.