Um JSON Web Token (JWT) é um padrão aberto para a transmissão segura de informações entre partes como um objeto JSON. Ele é frequentemente usado para autenticar usuários e transmitir informações com segurança entre um cliente e um servidor.
Quando um usuário faz login, o servidor cria um JWT, que é composto por três partes: um cabeçalho, um payload (carga útil) e uma assinatura.
O cabeçalho geralmente consiste no tipo de token e no algoritmo criptográfico usado para protegê-lo. O cabeçalho é então codificado em Base64Url.
O payload contém as declarações, que são afirmações sobre o usuário e dados adicionais. As declarações podem incluir informações como o ID do usuário, nome de usuário, função e qualquer outro dado relevante. O payload também é codificado em Base64Url.
A assinatura é criada codificando o cabeçalho, o payload e uma chave secreta usando o algoritmo especificado no cabeçalho. Isso garante a integridade do token e permite que o servidor verifique sua autenticidade. A assinatura é anexada ao cabeçalho e ao payload codificados para formar o JWT completo.
Uma vez criado o JWT, ele é enviado ao cliente, que o armazena e o envia junto com as solicitações subsequentes. O cliente normalmente inclui o JWT no cabeçalho Authorization
da solicitação HTTP como um token Bearer.
Ao receber o JWT, o servidor verifica sua assinatura usando a chave secreta. Se a assinatura for válida, o servidor pode decodificar as informações no cabeçalho e no payload para realizar a autenticação do usuário. O servidor pode confiar nas informações no JWT sem precisar consultar um banco de dados ou realizar verificações adicionais de autenticação. Isso torna os JWTs um mecanismo de autenticação eficiente e escalável.
A autenticação por token é um método de autenticação onde um token de acesso é usado para acessar recursos em vez de usar nome de usuário e senha. O token é geralmente emitido por um servidor de autenticação e é passado junto com cada solicitação como prova de autenticação. A autenticação baseada em token oferece várias vantagens sobre a autenticação tradicional de nome de usuário e senha:
OAuth 2.0 é um padrão aberto e um framework de autorização que permite que uma aplicação de terceiros obtenha acesso limitado aos recursos de um usuário. Ele é comumente usado para permitir que os usuários concedam permissões a aplicações externas para acessar seus dados em plataformas de terceiros. OAuth 2.0 depende de JSON Web Tokens (JWTs) para autenticação e autorização.
O OAuth 2.0 envolve várias partes, como o dono do recurso (o usuário que possui os recursos), o cliente (a aplicação de terceiros), o servidor de autorização (responsável por emitir tokens de acesso) e o servidor de recursos (que detém os recursos protegidos).
Durante o fluxo do OAuth 2.0, o cliente obtém uma concessão de autorização do dono do recurso. O cliente então troca essa concessão com o servidor de autorização por um token de acesso. O token de acesso é um JWT que contém as informações necessárias para acessar os recursos protegidos no servidor de recursos. Este token é então usado pelo cliente para acessar os recursos do usuário.
Ao usar OAuth 2.0 e JWTs, as aplicações podem fornecer acesso seguro e controlado aos dados dos usuários em uma ampla gama de plataformas.