
👋 Olá! Se você está começando no mundo do desenvolvimento back-end com Python, já deve ter ouvido falar do Flask — um framework leve, flexível e poderoso para criar aplicações web e APIs. Nesta matéria, vou guiar você passo a passo na construção de uma API RESTful simples usando Flask. Vamos desde a configuração do ambiente até a criação de endpoints básicos para operações CRUD (Create, Read, Update, Delete). Ao final, você terá uma API funcional e um conhecimento sólido para expandir seus projetos! 🚀
🧠 Por que usar Flask?
Flask é um microframework escrito em Python que facilita a criação de aplicações web e APIs. Diferente de frameworks mais robustos como Django, o Flask é minimalista e oferece apenas o essencial, dando mais liberdade ao desenvolvedor para escolher como estruturar seu projeto e quais bibliotecas usar. Isso o torna ideal para:
- Projetos pequenos a médios.
- APIs RESTful e microsserviços.
- Iniciantes que querem entender conceitos fundamentais sem muita complexidade.
Alguns fatos interessantes sobre Flask:
- É construído sobre as bibliotecas Werkzeug (para manipulação de requisições WSGI) e Jinja2 (para templates HTML).
- Não possui ORM (Object-Relational Mapping) embutido, permitindo que você use SQLAlchemy, Peewee ou até mesmo SQL puro.
- É amplamente utilizado para construir APIs RESTful devido à sua simplicidade e flexibilidade.
⚙️ Configuração do ambiente
Antes de começar, você precisa configurar seu ambiente de desenvolvimento. Siga os passos abaixo:
1. Instale o Python
Certifique-se de ter o Python 3.7 ou superior instalado. Você pode verificar a versão com:
python3 --version
2. Crie um ambiente virtual
Ambientes virtuais isolam as dependências do seu projeto. Isso evita conflitos entre bibliotecas de diferentes projetos.
python3 -m venv venv source venv/bin/activate # No Windows: venv\Scripts\activate
3. Instale o Flask
Com o ambiente virtual ativado, instale o Flask usando o pip:
pip install Flask
🚀 Criando sua primeira aplicação Flask
Vamos começar com um “Hello, World!” básico. Crie um arquivo chamado app.py e adicione o seguinte código:
from flask import Flask
app = Flask(__name__)
@app.route('/')
def hello_world():
return '<p>Hello, World!</p>'
if __name__ == '__main__':
app.run(debug=True)
Explicação:
Flask(__name__): Cria uma instância da aplicação Flask.@app.route('/'): Define uma rota para a URL raiz (/).hello_world(): Função que retorna uma resposta HTML.app.run(debug=True): Inicia o servidor de desenvolvimento com modo debug ativado (útil para ver erros detalhados e recarregamento automático).
Execute a aplicação:
python app.py
Acesse http://127.0.0.1:5000 no seu navegador. Você deve ver a mensagem “Hello, World!”.
🛠️ Construindo uma API RESTful simples
Agora, vamos criar uma API para gerenciar uma lista de itens. Usaremos uma estrutura de dados em memória para simular um banco de dados.
Estrutura básica da API
Adicione o seguinte código ao app.py:
from flask import Flask, jsonify, request
app = Flask(__name__)
# Banco de dados em memória
items = [
{"id": 1, "name": "Item 1"},
{"id": 2, "name": "Item 2"}
]
# Rota para listar todos os itens
@app.route('/items', methods=['GET'])
def get_items():
return jsonify(items)
# Rota para obter um item específico por ID
@app.route('/items/<int:item_id>', methods=['GET'])
def get_item(item_id):
item = next((item for item in items if item['id'] == item_id), None)
if item is None:
return jsonify({'error': 'Item not found'}), 404
return jsonify(item)
# Rota para criar um novo item
@app.route('/items', methods=['POST'])
def create_item():
new_item = {
'id': len(items) + 1,
'name': request.json.get('name')
}
items.append(new_item)
return jsonify(new_item), 201
# Rota para atualizar um item existente
@app.route('/items/<int:item_id>', methods=['PUT'])
def update_item(item_id):
item = next((item for item in items if item['id'] == item_id), None)
if item is None:
return jsonify({'error': 'Item not found'}), 404
item['name'] = request.json.get('name', item['name'])
return jsonify(item)
# Rota para deletar um item
@app.route('/items/<int:item_id>', methods=['DELETE'])
def delete_item(item_id):
global items
items = [item for item in items if item['id'] != item_id]
return '', 204
if __name__ == '__main__':
app.run(debug=True)
Funcionalidades implementadas:
- GET /items: Retorna todos os itens.
- GET /items/<id>: Retorna um item específico.
- POST /items: Cria um novo item.
- PUT /items/<id>: Atualiza um item existente.
- DELETE /items/<id>: Remove um item.
Teste a API com curl ou Postman:
- Para listar todos os itens:
curl http://127.0.0.1:5000/items - Para criar um novo item:
curl -X POST -H “Content-Type: application/json” -d ‘{“name”:”Novo Item”}’ http://127.0.0.1:5000/items
📦 Estruturando o projeto com Blueprints
Para projetos maiores, é recomendável usar Blueprints para organizar rotas em módulos. Isso melhora a mantenabilidade e escalabilidade do código.
Exemplo de uso de Blueprints:
- Crie uma pasta
blueprintse um arquivoitems.pydentro dela:
from flask import Blueprint, jsonify, request
items_bp = Blueprint('items_bp', __name__)
items = []
@items_bp.route('/items', methods=['GET'])
def get_items():
return jsonify(items)
# Adicione outras rotas aqui...
- No
app.py, registre o blueprint:
from blueprints.items import items_bp app = Flask(__name__) app.register_blueprint(items_bp)
🔧 Dicas importantes
- Modo Debug: Sempre use
debug=Truedurante o desenvolvimento, mas nunca em produção. - Escapamento HTML: Use
escapedo módulomarkupsafepara evitar ataques de injeção ao renderizar HTML com dados do usuário. - Virtualenv: Mantenha um ambiente virtual para cada projeto para gerenciar dependências.
- Tratamento de erros: Retorne códigos HTTP apropriados (e.g., 404 para recursos não encontrados).
📈 Próximos passos
Agora que você tem uma API básica, explore estes tópicos para aprofundar seus conhecimentos:
- Integração com banco de dados (SQLite, PostgreSQL, MySQL).
- Autenticação de usuários com Flask-Login ou JWT.
- Documentação automática com Swagger.
- Implantação em produção usando Gunicorn ou Nginx.
💡 Conclusão
Flask é uma ferramenta fantástica para iniciantes devido à sua simplicidade e flexibilidade. Com poucas linhas de código, você pode criar APIs poderosas e escaláveis. Espero que esta matéria tenha te ajudado a dar os primeiros passos! Agora, é só expandir seu projeto e explorar todo o potencial do Flask.
Se tiver dúvidas, consulte a documentação oficial ou fique à vontade para me procurar nas redes sociais. Bora codar! 😎




















