committed by
GitHub
2 changed files with 49 additions and 1 deletions
@ -0,0 +1,48 @@ |
|||
# Sobre HTTPS |
|||
|
|||
É fácil assumir que HTTPS é algo que é apenas "habilitado" ou não. |
|||
|
|||
Mas é bem mais complexo do que isso. |
|||
|
|||
!!! tip "Dica" |
|||
Se você está com pressa ou não se importa, continue com as seções seguintes para instruções passo a passo para configurar tudo com diferentes técnicas. |
|||
|
|||
Para aprender o básico de HTTPS de uma perspectiva do usuário, verifique <a href="https://howhttps.works/pt-br/" class="external-link" target="_blank">https://howhttps.works/pt-br/</a>. |
|||
|
|||
Agora, a partir de uma perspectiva do desenvolvedor, aqui estão algumas coisas para ter em mente ao pensar em HTTPS: |
|||
|
|||
* Para HTTPS, o servidor precisa ter certificados gerados por um terceiro. |
|||
* Esses certificados são adquiridos de um terceiro, eles não são simplesmente "gerados". |
|||
* Certificados têm um tempo de vida. |
|||
* Eles expiram. |
|||
* E então eles precisam ser renovados, adquirindo-os novamente de um terceiro. |
|||
* A criptografia da conexão acontece no nível TCP. |
|||
* Essa é uma camada abaixo do HTTP. |
|||
* Portanto, o manuseio do certificado e da criptografia é feito antes do HTTP. |
|||
* O TCP não sabe sobre "domínios". Apenas sobre endereços IP. |
|||
* As informações sobre o domínio solicitado vão nos dados HTTP. |
|||
* Os certificados HTTPS “certificam” um determinado domínio, mas o protocolo e a encriptação acontecem ao nível do TCP, antes de sabermos de que domínio se trata. |
|||
* Por padrão, isso significa que você só pode ter um certificado HTTPS por endereço IP. |
|||
* Não importa o tamanho do seu servidor ou quão pequeno cada aplicativo que você tem nele possa ser. |
|||
* No entanto, existe uma solução para isso. |
|||
* Há uma extensão para o protocolo TLS (aquele que lida com a criptografia no nível TCP, antes do HTTP) chamado <a href="https://en.wikipedia.org/wiki/Server_Name_Indication" class="external-link" target="_blank"><abbr title="Server Name Indication">SNI</abbr></a>. |
|||
* Esta extensão SNI permite que um único servidor (com um único endereço IP) tenha vários certificados HTTPS e atenda a vários domínios / aplicativos HTTPS. |
|||
* Para que isso funcione, um único componente (programa) em execução no servidor, ouvindo no endereço IP público, deve ter todos os certificados HTTPS no servidor. |
|||
* Depois de obter uma conexão segura, o protocolo de comunicação ainda é HTTP. |
|||
* Os conteúdos são criptografados, embora sejam enviados com o protocolo HTTP. |
|||
|
|||
É uma prática comum ter um programa/servidor HTTP em execução no servidor (máquina, host, etc.) e gerenciar todas as partes HTTPS: enviando as solicitações HTTP descriptografadas para o aplicativo HTTP real em execução no mesmo servidor (a aplicação **FastAPI**, neste caso), pegue a resposta HTTP do aplicativo, criptografe-a usando o certificado apropriado e envie-a de volta ao cliente usando HTTPS. Este servidor é frequentemente chamado de <a href="https://en.wikipedia.org/wiki/TLS_termination_proxy" class="external-link" target="_blank">TLS Termination Proxy</a>. |
|||
|
|||
## Let's Encrypt |
|||
|
|||
Antes de Let's Encrypt, esses certificados HTTPS eram vendidos por terceiros confiáveis. |
|||
|
|||
O processo de aquisição de um desses certificados costumava ser complicado, exigia bastante papelada e os certificados eram bastante caros. |
|||
|
|||
Mas então <a href="https://letsencrypt.org/" class="external-link" target="_blank">Let's Encrypt</a> foi criado. |
|||
|
|||
Ele é um projeto da Linux Foundation que fornece certificados HTTPS gratuitamente. De forma automatizada. Esses certificados usam toda a segurança criptográfica padrão e têm vida curta (cerca de 3 meses), então a segurança é realmente melhor por causa de sua vida útil reduzida. |
|||
|
|||
Os domínios são verificados com segurança e os certificados são gerados automaticamente. Isso também permite automatizar a renovação desses certificados. |
|||
|
|||
A ideia é automatizar a aquisição e renovação desses certificados, para que você tenha HTTPS seguro, de graça e para sempre. |
Loading…
Reference in new issue