Escrevendo seu primeiro app Django, parte 1¶
Vamos aprender por um exemplo.
Através deste tutorial, nós vamos caminhar através da criação de uma aplicação básica de enquetes.
Ela irá consistir de duas partes:
- Uma página pública que permitirá que pessoas vejam as enquetes e votem nelas.
- Um site de administração que permite adicionar, alterar e deletar enquetes.
Assumiremos que você já tem o Django instalado. Você pode verificar se o Django está instalado e em qual versão rodando o seguinte comando em um prompt shell (indicado pelo prefixo $):
$ python -m django --version
...\> py -m django --version
Se o Django estiver instalado, você verá a versão de sua instalação. Se não estiver, você receberá uma mensagem de erro dizendo “No module named django”.
Este tutorial foi escrito para Django 4.2, que suporta Python 3.8 e posterior. Se a versão do Django não corresponder, você pode consultar o tutorial da sua versão do Django usando o seletor de versão no canto inferior direito desta página ou atualizar o Django para a versão mais recente. Se você estiver usando uma versão mais antiga do Python, verifique Qual versão do Python eu posso usar com Django? para encontrar uma versão compatível do Django.
Veja Como instalar o Django para recomendação sobre como remover versões antigas do Django e instalar uma mais recente.
Onde obter ajuda:
Se tiver problemas enquanto caminha por este tutorial, por favor consulte a seção Obtendo ajuda da FAQ.
Criando um projeto¶
Se esta é a primeira vez em que você está utilizando o Django, você terá que preocupar-se com algumas configurações iniciais. Isto é, você precisará auto-gerar um código para iniciar um projeto Django – uma coleção de configurações para uma instância do Django, incluindo configuração do banco de dados, opções específicas do Django e configurações específicas da aplicação.
A partir da linha de comando, execute cd
para o diretório onde você gostaria de armazenar seu código, então execute o seguinte comando:
$ django-admin startproject mysite
...\> django-admin startproject mysite
Isto irá criar o diretório mysite
no seu diretório atual. Se não funcionar, veja Problemas ao rodar o django-admin.
Nota
Você precisará evitar dar nomes a projetos que remetam a componentes internos do Python ou do Django. Particularmente, isso significa que você deve evitar usar nomes como django
(que irá conflitar com o próprio Django) ou test
(que irá conflitar com um pacote interno do Python).
Onde esse código deveria existir?
Se o seu background é em PHP simples (sem o uso de frameworks modernos), você provavelmente está acostumado a colocar o código na raiz do documento do servidor web (em um local como /var/www
). Com Django, você não faz isso. Não é uma boa ideia colocar nenhum desses códigos Python na raiz de documentos do seu servidor web, pois isso facilita o acesso de visualização do seu código na web por outras pessoas. Isso não é bom para a segurança.
Coloque seu código em algum diretório fora do document root, como em /home/mycode
.
Veja a estrutura de diretório criada com o comando startproject
:
mysite/
manage.py
mysite/
__init__.py
settings.py
urls.py
asgi.py
wsgi.py
Esses arquivos são:
- O diretório raiz
mysite/
é um contêiner para o seu projeto. Seu nome não importa para o Django; você pode renomeá-lo para qualquer nome que você quiser. manage.py
: um utilitário de linha de comando que permite a você interagir com esse projeto Django de várias maneiras. Você pode ler todos os detalhes sobre omanage.py
em django-admin and manage.py.- O diretório
mysite/
interior é o pacote Python para o seu projeto. Seu nome é o nome do pacote Python que você vai precisar usar para importar coisas do seu interior (por exemplo,mysite.urls
). mysite/__init__.py
: um arquivo vazio que diz ao Python que este diretório deve ser considerado um pacote Python. Se você é um iniciante Python, leia mais sobre pacotes na documentação oficial do Python.mysite/settings.py
: configurações para este projeto Django. Configurações do Django irá revelar para você tudo sobre o funcionamento dosettings
.mysite/urls.py
: as declarações de URLs para este projeto Django; um “índice” de seu site movido a Django. Você pode ler mais sobre URLs em Despachante de URL.mysite/asgi.py
: um ponto de integração para servidores web compatíveis com ASGI usado para servir seu projeto. Veja Como fazer o deploy com ASGI para mais detalhes.mysite/wsgi.py
: um ponto de integração para servidores web compatíveis com WSGI usado para servir seu projeto. Veja Como implementar com WSGI para mais detalhes.
O servidor de desenvolvimento¶
Vamos verificar se ele funciona. Vá para o diretório mysite
, se você ainda não estiver nele, e execute o seguinte comando:
$ python manage.py runserver
...\> py manage.py runserver
Você verá a seguinte saída na sua linha de comando:
Performing system checks... System check identified no issues (0 silenced). You have unapplied migrations; your app may not work properly until they are applied. Run 'python manage.py migrate' to apply them. dezembro 04, 2023 - 15:50:53 Django version 4.2, using settings 'mysite.settings' Starting development server at http://127.0.0.1:8000/ Quit the server with CONTROL-C.
Nota
Por hora, ignore os avisos sobre as migrações do banco de dados não aplicadas; lidaremos com o banco de dados brevemente.
Você iniciou o servidor de desenvolvimento do Django, um servidor web leve escrito exclusivamente em Python. Incluímos isso no Django para que você possa desenvolver coisas rapidamente, sem ter que lidar com a configuração de um servidor de produção – como o Apache – até que esteja pronto para a produção.
Agora, uma boa recomendação: não use esse servidor em ambiente de produção. Porque ele foi planejado apenas para desenvolvimento. (Nosso objetivo é criar um framework web e não um servidor web).
Agora que o servidor está funcionando, visite http://127.0.0.1:8000/ no seu navegador web. Você verá uma página de “Congratulations!”, com um foguete decolando. Funcionou!
Alterando a porta
Por padrão, o comando runserver
inicia o servidor de desenvolvimento no IP interno na porta 8000.
Se você quer mudar a porta do servidor, passe ela como um argumento na linha de comando. Por exemplo, este comando iniciará o servidor na porta 8080:
$ python manage.py runserver 8080
...\> py manage.py runserver 8080
Se você quer mudar o IP do servidor, passe junto com a porta. Por exemplo, para escutar em todos os IPs públicos disponívies (o que é útil se estiver usando Vagrant ou quer mostrar seu trabalho para outros computadores na rede), use:
$ python manage.py runserver 0.0.0.0:8000
...\> py manage.py runserver 0.0.0.0:8000
A documentação completa para o servidor de desenvolvimento está na referência runserver
.
Recarregamento automático do runserver
O servidor de desenvolvimento recarrega o código Python para cada solicitação, conforme necessário. Você não precisa reiniciar o servidor para que alterações de código tenham efeito. No entanto, algumas ações como a adição de arquivos não disparam uma reinicialização, então você terá que reiniciar o servidor nestes casos.
Criando a aplicação de enquetes: Polls¶
Agora que seu ambiente – um “projeto” – está configurado, você está pronto para começar o trabalho.
Cada aplicação que você escreve no Django consiste de um pacote Python que segue uma certa convenção. O Django vem com um utilitário que gera automaticamente a estrutura básica de diretório de uma aplicação, então você pode se concentrar apenas em escrever código em vez de ficar criando diretórios.
Projetos versus aplicações
Qual a diferença entre um projeto e um app? Um app é uma aplicação web que executa algo, por exemplo: um sistema de blog, uma base de dados de registros públicos ou uma pequena aplicação de enquete. Um projeto é uma coleção de configurações e apps para um website específico. Um projeto pode conter múltiplos apps. Um app pode estar em múltiplos projetos.
Suas aplicações, ou “apps”, podem ficar em qualquer lugar dentro do seu caminho de busca de módulos Python. Neste tutorial, iremos criar nossa “app” de enquete no mesmo diretório que seu arquivo manage.py
para que possa ser importado como um módulo de nível superior dentro do projeto, ao invés de ser um submódulo de mysite
.
Para criar sua aplicação, certifique-se de que esteja no mesmo diretório que manage.py
e digite o seguinte comando:
$ python manage.py startapp polls
...\> py manage.py startapp polls
Isto criará um diretório polls
, com a seguinte estrutura:
polls/
__init__.py
admin.py
apps.py
migrations/
__init__.py
models.py
tests.py
views.py
Esta estrutura de diretório irá abrigar a aplicação de enquete.
Escreva sua primeira view¶
Hora de criar a primeira view. Abra o arquivo polls/views.py
e ponha o seguinte código em Python dentro dele:
from django.http import HttpResponse
def index(request):
return HttpResponse("Hello, world. You're at the polls index.")
Esta é a view mais simples possível no Django. Para chamar a view, nós temos que mapear a URL - e para isto nós precisamos de uma URLconf.
Para criar uma URLconf no diretório polls, crie um arquivo chamado``urls.py``. O diretório do seu app deverá ficar da seguinte forma:
polls/
__init__.py
admin.py
apps.py
migrations/
__init__.py
models.py
tests.py
urls.py
views.py
No arquivo polls/urls.py
inclua o seguinte código:
from django.urls import path
from . import views
urlpatterns = [
path("", views.index, name="index"),
]
O próximo passo é apontar na raiz da URLconf para o módulo polls.urls
. No arquivo mysite/urls.py
, adicione uma importação de django.urls.include
e insira um include()
na lista urlpatterns
, de forma que você tenha:
from django.contrib import admin
from django.urls import include, path
urlpatterns = [
path("polls/", include("polls.urls")),
path("admin/", admin.site.urls),
]
A função include()
permite referenciar outras URLconfs. Qualquer lugar que o Django encontrar include()
, irá recortar todas as partes da URL encontrada até aquele ponto e enviar a string restante para URLconf incluído para processamento posterior.
A idéia por trás do include()
é facilitar plugar URLs. Uma vez que polls está em sua própria URLconf (polls/urls.py
), ele pode ser colocado depois de “/polls/”, ou depois de “/fun_polls/”, u depois de “/content/polls/”, ou qualquer outro início de caminho, e a aplicação ainda irá funcionar
Quando usar include()
Deve-se sempre usar include()
quando você incluir outros padrões de URL. admin.site.urls
é a única exceção a isso.
Agora você amarrou uma view index
no seu URLconf. Verique se funciona com o seguinte comando:
$ python manage.py runserver
...\> py manage.py runserver
Acesse http://localhost:8000/polls/ no seu navegador, e deverá ver o texto “Hello, world. You’re at the polls index.”, o qual foi definido na view “index”.
Página não encontrada?
Se retornar uma página de erro, verifique se está acessando http://localhost:8000/polls/ e não http://localhost:8000/.
A função path()
são passado quatro argumentos, dois obrigatórios: route
e view
, e dois opcionais: kwargs
, e name
. Neste ponto, vale a pena revisar para o que estes argumentos servem.
Argumento de path()
: route
¶
route
é uma string contento uma descrição de uma URL. Quando processa uma requisição, o Django começa pela primeira descrição, e vai descendo a lista, comparando a URL requisitada com cada descrição até que encontre uma que combine.
Descrições não distinguem paramentros GET e POST, ou o nome do domínio. Por exemplo, em uma requisição https://www.example.com/myapp/
, o URLconf irá procurar por myapp/
. Em uma requisição para https://www.example.com/myapp/?page=3`, o URLconf também irá procurar por ``myapp/
.
Argumento de path()
: view
¶
Quando o Django encontra uma descrição que combina, chama a função view especificada com um objeto HttpRequest
como primeiro argumento e qualquer valor “capturado” da rota como argumentos keyword. Daremos um exemplo sobre isso logo.
Argumento de path()
: kwargs
¶
Argumentos nomeados arbitrários podem ser passadas em um dicionário para a view de destino. Nós não vamos usar este recurso do Django neste tutorial.
Argumento de path()
: name
¶
Nomear sua URL permite que você referencie ela de forma inequívoca de qualquer lugar no Django especialmente nos templates. Este poderoso recurso permite que você faça alterações globais nos padrões de URL de seu projeto enquanto modifica um único arquivo.
Quando estiver confortável com o básico da sequência de requisição e resposta, leia a parte 2 desse tutorial para começar a trabalhar com banco de dados.