Autenticação com o framework CakePHP
Dica publicada em Linux / Introdução
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:
2. Adicione o componente de autenticação no app_controller de sua aplicação. Edite o arquivo app/app_controller.php e acrescente:
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:
5. Devemos criar no controller dos usuários as funções para login e logout.
Acrescente em app/controller/controllers/usuario_controller.php:
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:
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:
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.
É isso! Obrigado.
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)
);
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'
);
}
$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());
}
}
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:
Login
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.
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 ;]