Observação
O acesso a essa página exige autorização. Você pode tentar entrar ou alterar diretórios.
O acesso a essa página exige autorização. Você pode tentar alterar os diretórios.
por Mike Wasson
A autenticação de formulários usa um formulário HTML para enviar as credenciais do usuário para o servidor. Não é um padrão da Internet. A autenticação de formulários só é apropriada para APIs Web chamadas de um aplicativo Web, para que o usuário possa interagir com o formulário HTML.
| Vantagens | Desvantagens |
|---|---|
|
|
Brevemente, a autenticação de formulários no ASP.NET funciona assim:
- O cliente solicita um recurso que requer autenticação.
- Se o usuário não estiver autenticado, o servidor retornará HTTP 302 (Encontrado) e redirecionará para uma página de logon.
- O usuário insere credenciais e envia o formulário.
- O servidor retorna outro HTTP 302 que redireciona de volta para o URI original. Essa resposta inclui um cookie de autenticação.
- O cliente solicita o recurso novamente. A solicitação inclui o cookie de autenticação, portanto, o servidor concede a solicitação.
Para obter mais informações, consulte Uma visão geral da autenticação de formulários.
Usando a Autenticação de Formulários com a API Web
Para criar um aplicativo que usa a autenticação de formulários, selecione o modelo "Aplicativo da Internet" no assistente de projeto do MVC 4. Esse modelo cria controladores MVC para gerenciamento de conta. Você também pode usar o modelo "Aplicativo de Página Única", disponível no ASP.NET Atualização de Outono de 2012.
Em seus controladores de API Web, você pode restringir o acesso usando o [Authorize] atributo, conforme descrito em Usar o Atributo [Autorizar].
A autenticação de formulários usa um cookie de sessão para autenticar solicitações. Os navegadores enviam automaticamente todos os cookies relevantes para o site de destino. Esse recurso torna a autenticação de formulários potencialmente vulnerável a ataques de CSRF (falsificação de solicitação entre sites). Veja Como prevenir ataques de CSRF (Cross-Site Request Forgery).
A autenticação de formulários não criptografa as credenciais do usuário. Portanto, a autenticação de formulários não é segura, a menos que seja usada com SSL. Consulte Como trabalhar com SSL na API Web.