Autenticação com o framework CakePHP

Publicado por Andre Dias em 01/07/2009

[ Hits: 9.789 ]

 


Autenticação com o framework CakePHP



Nesta dica pretendo explicar como fazer uma simples autenticação usando o framework cakePHP.

1. O primeiro passo é criar suas tabelas, no meu exemplo estou usando o MySQL. Crie as tabelas que serão usadas:

CREATE TABLE usuarios (
   id integer auto_increment,
   nome char(50),
   login char(50),
   password char(50),
   grupo_id integer,      
   PRIMARY KEY (id)
);
CREATE TABLE grupos (
   id integer auto_increment,
   nome char(50),      
   PRIMARY KEY (id)
);

2. Adicione o componente de autenticação no app_controller de sua aplicação. Edite o arquivo app/app_controller.php e acrescente:

var $components = array('Auth');

3. Usando o cake bake crie: controllers, visões, modelos de: usuários, grupos.

4. Como não estamos usando a tabela com nome "users", devemos alterar o padrão com informações de nossa tabela.

No app_controller devemos acrescentar:

function beforeFilter(){
   $this->Auth->userModel='Usuario';
   $this->Auth->fields=array(
      'username'=>'login',
      'password'=>'senha'
   );
}

5. Devemos criar no controller dos usuários as funções para login e logout.

Acrescente em app/controller/controllers/usuario_controller.php:

function login(){
}

function logout(){
   $this->Session->setFlash('Ate +');
   $this->redirect($this->Auth->logout());
}

6. Devemos criar a visão para a tela de login que o usuário usará para autenticação.

Crie o arquivo dentro de views/usuarios/login.ctp:

<h2>Login</h2>

<?php
   echo $form->create('Usuario',
   array('url' => array(
      'controller' => 'usuarios',
      'action' =>'login')));
   echo $form->input('Usuario.login');
   echo $form->input('Usuario.senha',array('type'=>'password'));
   echo $form->end('Login');
?>

7. Após seguir estes passos seu sistema já autenticará quando você tentar acessar alguma função.

Para que você tenha permissão de acessar todas as funções para poder acrescentar um usuário para teste, edite o arquivo app/app_controller.php e dentro de "beforefilter" coloque:

   $this->Auth->allow('*');

Dessa forma será possível acrescentar usuários.

Após acrescentar os usuários, edite novamente este arquivo colocando as permissões para um usuário sem autenticação. Neste caso estarei permitindo que apenas veja o index visualize os dados.

   $this->Auth->allow('index','view');

É isso! Obrigado.

Outras dicas deste autor
Nenhuma dica encontrada.
Leitura recomendada

O Fantástico Damn Small Linux (DSL) - 50 Megabytes com a força do pinguim

Configurando um servidor de e-mail colaborativo Zimbra

Internet Velox ou Bridge no SuSE

Instalação do driver Nvidia com o Envy + gerenciador de janelas Beryl

BIND 9 DNS no Debian Squeeze/Wheezy e Ubuntu 12/13 (Compativel com Active Directory no Windows Server)

  

Comentários
[1] Comentário enviado por dotti em 01/07/2009 - 16:38h

Opa Andre, algumas correções de coisas que devem ter passadas despercebidas na hora de transcrever a dica:

No item 4:

Onde está

$this->Auth->fields=array(
'username'=>'login',
'password'=>'senha'
);

Deveria ser

$this->Auth->fields=array(
'username'=>'login',
'password'=>'password' //este é o nome que foi dado ao campo com senha no BD
);

---
No item 5, o nome correto do controller deve ser "usuarios_controller.php" , lembrando que nome dos controladores são sempre no plural em relação ao modelo/entidade (usuario => usuarios)

Valeu a iniciativa ;]

[2] Comentário enviado por mbmaciel em 14/01/2010 - 10:27h

Funcionou ! Valeu!



Contribuir com comentário




Patrocínio

Site hospedado pelo provedor RedeHost.
Linux banner
Linux banner
Linux banner

Destaques

Artigos

Dicas

Tópicos

Top 10 do mês

Scripts