Tokens JWT
Os JSON Web Tokens (JWT) oferecem um método seguro para transmitir informação entre partes sob a forma de um objeto JSON.
Estrutura de um JWT
Um JWT é composto por três partes separadas por pontos:
header.payload.signatureCabeçalho
{ "alg": "HS256", "typ": "JWT"}Payload
{ "sub": "1234567890", "iat": 1516239022, "exp": 1516242622}Assinatura
A assinatura é criada com:
HMACSHA256( base64UrlEncode(header) + "." + base64UrlEncode(payload), secret)Criar tokens JWT
Exemplo em Node.js
const jwt = require('jsonwebtoken');
const payload = { userId: '12345', scope: ['email', 'contacts']};
const token = jwt.sign(payload, process.env.JWT_SECRET, { expiresIn: '1h', issuer: 'your-app', audience: 'brevo-api'});Exemplo em Python
import jwtimport datetime
payload = { 'user_id': '12345', 'exp': datetime.datetime.utcnow() + datetime.timedelta(hours=1), 'iat': datetime.datetime.utcnow()}
token = jwt.encode(payload, 'your-secret-key', algorithm='HS256')Usar JWT com a API Brevo
curl -X GET "https://api.brevo.com/v3/account" \ -H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9..." \ -H "Accept: application/json"Validação do token
const validateToken = (token) => { try { const decoded = jwt.verify(token, process.env.JWT_SECRET); return { valid: true, payload: decoded }; } catch (error) { return { valid: false, error: error.message }; }};Boas práticas
- Utiliza secrets fortes e aleatórios
- Define tempos de expiração adequados
- Valida os tokens em cada pedido
- Usa apenas HTTPS
- Guarda os secrets de forma segura
- Implementa lógica de atualização de token