SlideShare uma empresa Scribd logo
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
Implementando o
Login e Logout
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
Hoje nós iremos aprender a criar uma função de Login e Logout para os clientes no
Mercado Online, e hoje nós faremos as seguintes configurações:
• Criaremos um formulário para Login;
• Criaremos a função de Login;
• Aprenderemos a utilizar a Session;
• Criaremos a função de Logout;
• Aprenderemos a utilizar o Anchor;
• Aprenderemos a utilizar o FlashData.
• Exercício;
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
Inicialmente para criar um sistema de login, precisaremos de alguns dados do
cliente para autenticar, neste caso utilizaremos o E-mail e Senha para autenticar,
precisaremos de um formulário de Login, e este formulário deve enviar as
informações para um novo controller chamado login que terá apenas o método
autenticar.
Utilize o helper FORM para lhe auxiliar.
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
No controller login, criaremos a função autentica e dentro desta função pegaremos
o E-mail e Senha que o usuário informou, e consultaremos no nosso Banco de Dados
para verificar se existe algum cadastro com o e-mail e senha informados. Para verificar
criaremos uma função no Usuarios_model chamado autentica, que receberá o
e-mail e senha.
Lembre-se de transformar a senha em MD5.
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
Nosso Controller deve estar semelhante a este:
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
Agora vamos criar nossa função autentica no usuarios_model. Para criar essa função
devemos receber como parâmetro um usuário, porém temos que verificar se o
E-mail e senha estão no nosso banco de dados e depois retorna se achou ou se não achou,
para verificar dados específicos em um Banco de dados precisamos utilizar um Where.
Porém como fazer isso no CodeIgniter?
Podemos fazer de duas maneiras simples.
1. Antes de consultar informa o Where;
2. Mudar nosso código para utilizar o get_where, que passamos a tabela e uma array
com os dados do Where.
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
1. Informando o Where antes da consulta:
public function autentica($usuario){
$this->db->where("email", $usuario["email"]);
$this->db->where("senha", $usuario["senha"]);
$usuario = $this->db->get("usuarios")->row_array();
return $usuario;
}
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
2. Utilizando o get_where:
public function autentica($usuario){
$usuario = $this->db->get_where("usuarios", array(
"email"=>$usuario["email"],
"senha"=>$usuario["senha"])
)->row_array();
return $usuario;
}
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
Agora nós temos nosso código que verifica se existe um usuário com o E-mail e Senha
Informados. Porém, aonde vamos armazenar aquele resultado?
Seria legal que depois que localizarmos um usuário criar uma sessão para ele, algo que
só o usuário que eu acabei de achar e o servidor tivessem.
No CodeIgniter existe uma função chamada userdata, que fica dentro da classe session,
para adicionar um valor nesta função, utiliza o set_userdata, mas vamos passar uma
Mensagem também, para deixar nosso código mais compreensível para o usuário, e depois
Direcionaremos para uma view que exibirá está mensagem.
Então nosso código irá ficar semelhante a este:
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de LimaRealize um teste, utilizando o seu usuário cadastrado.
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
Só que quando vamos testar, ele já cai em um erro.
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
Mas espera um momento, nós já vimos este erro em outro slide:
A PHP Error was encountered
Severity: Notice
Message: Undefined property: Login::$session
Filename: controllers/login.php
Erro de propriedade indefinida?
Neste caso, nossa propriedade está correta, mas porque não está carregando?
Por um simples e pequeno motivo, esquecemos de carregar a library da session, mas a
Session é algo muito importante para todo meu código e eu vou utilizar bastante ela.
Então vamos voltar no AutoLoad, e além de carregar o database, iremos carregar a
Session automaticamente.
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
Mas se eu já fiz o login no sistema, não quero que apareça o formulário para fazer o login
Ou o formulário de cadastro novamente, eu quero que apareça apenas os produtos.
E se eu estou logado no sistema, eu também quero fazer o Logout.
Vamos fazer uma parte de cada vez:
1. Alteraremos a index, para caso estejamos logados, não exibir os formulários;
2. Criar um botão para fazer o logout;
3. Melhorar a visualização da mensagem de “Logado com Sucesso” ou
“Login ou Senha inválidas”;
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
Começaremos com o mais fácil e rápido, vá na pasta Produtos e no arquivo Index.php,
e antes de criar os formulários faça uma verificação utilizando um if.
- Mas if o que?
Se nós utilizamos o set_userdata, para atribuir um valor no userdata, vamos utiliza-lo
Para verificar se existe algum valor “setado” ou não.
Para realizar esta verificação fazemos:
<?php if($this->session->userdata("usuario_logado")) : ?>
E logo após criarmos o ultimo formulário, terminaremos o nosso if:
<?php endif ?>
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
Agora que fazemos uma verificação para ver se tem algum usuário
ativo ou não no sistema, só que falto o botão de deslogar. Para criar
este botão, utilizaremos um anchor, que recebe 3 parâmetros,
o primeiro é qual a ação dele quando clicado, o segundo é o nome que
será exibido e o terceiro é um array que contem as informações dele,
como class, id, name e outras Tag de HTML.
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
Nosso anchor direciona para o login/logout, porém ainda não criamos está função.
Vamos no Controller Login e criaremos a função logout, que ela ira retirar o valor
do login.
public function logout(){
$this->session->unset_userdata("usuario_logado");
}
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
Agora nós temos um sistema de Login e Logout de usuários, mas ainda falta melhorar
na questão das mensagens, seria legal utilizar alguma função que exibisse a mensagem
apenas uma vez e depois desaparecesse.
Para isso nós temos a função flashdata, que recebe 2 parâmetros.
O Primeiro parâmetro é o nome do flashdata e o segundo é a mensagem que dele.
Vamos adicionar um valor no flashdata quando fazemos o login. Para isso retorne a função
Autenticar e caso ele ache um usuário, adicione uma mensagem de:
“Login realizado com sucesso”
E depois, redirecione para a pagina inicial.
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
Depois de ter criado a mensagem, vamos exibi-la.
Vá na pasta Produtos e abra o arquivo Index, e antes da
tag h1 Produtos, verifique se tem algum flashdata do tipo
“success”, e se tiver vamos exibi-lo.
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
Este é o código que deve ser adicionado na Index:
<?php if($this->session->flashdata("success")) : ?>
<p style="text-align:center;" class="alert alert-success">
<?= $this->session->flashdata("success"); ?> </p>
<?php endif ?>
Agora temos uma index mais bonita e com uma mensagem mais agradavel.
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
Exercicio
Implementando o Login e Logout
Exibindo mensagens com o FlashData
Criado por: Raniere de Lima
Crie um flashdata para caso o login ou senha
estiverem erradas, e para quando o Logout
for realizado.

Mais conteúdo relacionado

PPTX
Slide 06 adicionando produtos e mostrando produto selecionado
PPTX
Slide 03 conectando no banco de dados, criação de helpers
PPTX
Slide 07 editando produto selecionando e excluindo produto
PPTX
Slide 04 adicionando usuários e conhecendo o auto load
PDF
Daw slide 08
PDF
Daw slide 07
PDF
Daw slide 06
PDF
evergreen_outdoor_handbook_2015
Slide 06 adicionando produtos e mostrando produto selecionado
Slide 03 conectando no banco de dados, criação de helpers
Slide 07 editando produto selecionando e excluindo produto
Slide 04 adicionando usuários e conhecendo o auto load
Daw slide 08
Daw slide 07
Daw slide 06
evergreen_outdoor_handbook_2015

Destaque (8)

DOCX
Cómo defenderse del bullying
PPTX
ITQAN Presentation - MEDIA.PPTX
PDF
Em terra de google, quem tem tradutor é rei
DOC
PDF
اعرف شخصيتك وشخصية_الآخرين_#إليك
PDF
Google Tag Manager для eCommerce
PDF
Bid robot DSP ru
PPT
080429 PréSentation Projet EuropéEn E Sangathan Anpe Cadres
Cómo defenderse del bullying
ITQAN Presentation - MEDIA.PPTX
Em terra de google, quem tem tradutor é rei
اعرف شخصيتك وشخصية_الآخرين_#إليك
Google Tag Manager для eCommerce
Bid robot DSP ru
080429 PréSentation Projet EuropéEn E Sangathan Anpe Cadres
Anúncio

Semelhante a Slide 05 implementando o login , logout e flash data (14)

PPT
Progweb Aula8
PDF
Php12
PDF
Rafael Garcia - Yii Framework, principais características e em ação
PDF
Criando controle de acesso com php e my sql
PDF
PHP Aula 05 - E-mails, Cookies e Sessoes
PPT
Prog web 03-php-sessoes-cookies_cabecalhos
PPT
ZF Básico - 6. Autenticação
ODP
Prog web 03-php-sessoes-cookies_cabecalhos
PPT
PHP FrameWARks - FISL
PDF
Sistema php
PDF
Aula 11 - Controle de sessão em PHP - Programação Web
PPTX
Manipulação de formulários com PHP. Uso de Cookies e Session com PHP.
PPTX
Programação web ii aulas 05 e 06
PPTX
PHP robusto com Zend Framework
Progweb Aula8
Php12
Rafael Garcia - Yii Framework, principais características e em ação
Criando controle de acesso com php e my sql
PHP Aula 05 - E-mails, Cookies e Sessoes
Prog web 03-php-sessoes-cookies_cabecalhos
ZF Básico - 6. Autenticação
Prog web 03-php-sessoes-cookies_cabecalhos
PHP FrameWARks - FISL
Sistema php
Aula 11 - Controle de sessão em PHP - Programação Web
Manipulação de formulários com PHP. Uso de Cookies e Session com PHP.
Programação web ii aulas 05 e 06
PHP robusto com Zend Framework
Anúncio

Último (19)

PPTX
Gestao-de-Bugs-em-Software-Introducao.pptxxxxxxxx
PPTX
BANCO DE DADOS - AULAS INICIAIS-sgbd.pptx
PDF
Apple Pippin Uma breve introdução. - David Glotz
PPTX
Como-se-implementa-um-softwareeeeeeeeeeeeeeeeeeeeeeeee.pptx
PPTX
Aula 18 - Manipulacao De Arquivos python
PDF
Otimizador de planejamento e execução no SAP Transportation Management, TM120...
PDF
Mergulho profundo técnico para gestão de transportes no SAP S/4HANA, S4TM6 Col14
PDF
Aula04-Academia Heri- Tecnologia Geral 2025
PDF
Processos na gestão de transportes, TM100 Col18
PPTX
Informática Aplicada Informática Aplicada Plano de Ensino - estudo de caso NR...
PDF
Custos e liquidação no SAP Transportation Management, TM130 Col18
PPTX
Aula16ManipulaçãoDadosssssssssssssssssssssssssssss
PDF
Gestão de transportes básica no SAP S/4HANA, S4611 Col20
PPTX
Programação - Linguagem C - Variáveis, Palavras Reservadas, tipos de dados, c...
PDF
20250805_ServiceNow e a Arquitetura Orientada a Serviços (SOA) A Base para Ap...
PDF
COBITxITIL-Entenda as diferença em uso governança TI
PDF
Fundamentos de gerenciamento de ordens e planejamento no SAP TransportationMa...
PDF
Custos e faturamento no SAP S/4HANA Transportation Management, S4TM3 Col26
PDF
Fullfilment AI - Forum ecommerce 2025 // Distrito e Total Express
Gestao-de-Bugs-em-Software-Introducao.pptxxxxxxxx
BANCO DE DADOS - AULAS INICIAIS-sgbd.pptx
Apple Pippin Uma breve introdução. - David Glotz
Como-se-implementa-um-softwareeeeeeeeeeeeeeeeeeeeeeeee.pptx
Aula 18 - Manipulacao De Arquivos python
Otimizador de planejamento e execução no SAP Transportation Management, TM120...
Mergulho profundo técnico para gestão de transportes no SAP S/4HANA, S4TM6 Col14
Aula04-Academia Heri- Tecnologia Geral 2025
Processos na gestão de transportes, TM100 Col18
Informática Aplicada Informática Aplicada Plano de Ensino - estudo de caso NR...
Custos e liquidação no SAP Transportation Management, TM130 Col18
Aula16ManipulaçãoDadosssssssssssssssssssssssssssss
Gestão de transportes básica no SAP S/4HANA, S4611 Col20
Programação - Linguagem C - Variáveis, Palavras Reservadas, tipos de dados, c...
20250805_ServiceNow e a Arquitetura Orientada a Serviços (SOA) A Base para Ap...
COBITxITIL-Entenda as diferença em uso governança TI
Fundamentos de gerenciamento de ordens e planejamento no SAP TransportationMa...
Custos e faturamento no SAP S/4HANA Transportation Management, S4TM3 Col26
Fullfilment AI - Forum ecommerce 2025 // Distrito e Total Express

Slide 05 implementando o login , logout e flash data

  • 1. Implementando o Login e Logout Exibindo mensagens com o FlashData Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima
  • 2. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima Implementando o Login e Logout
  • 3. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima Hoje nós iremos aprender a criar uma função de Login e Logout para os clientes no Mercado Online, e hoje nós faremos as seguintes configurações: • Criaremos um formulário para Login; • Criaremos a função de Login; • Aprenderemos a utilizar a Session; • Criaremos a função de Logout; • Aprenderemos a utilizar o Anchor; • Aprenderemos a utilizar o FlashData. • Exercício;
  • 4. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima Inicialmente para criar um sistema de login, precisaremos de alguns dados do cliente para autenticar, neste caso utilizaremos o E-mail e Senha para autenticar, precisaremos de um formulário de Login, e este formulário deve enviar as informações para um novo controller chamado login que terá apenas o método autenticar. Utilize o helper FORM para lhe auxiliar.
  • 5. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima No controller login, criaremos a função autentica e dentro desta função pegaremos o E-mail e Senha que o usuário informou, e consultaremos no nosso Banco de Dados para verificar se existe algum cadastro com o e-mail e senha informados. Para verificar criaremos uma função no Usuarios_model chamado autentica, que receberá o e-mail e senha. Lembre-se de transformar a senha em MD5.
  • 6. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima Nosso Controller deve estar semelhante a este:
  • 7. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima Agora vamos criar nossa função autentica no usuarios_model. Para criar essa função devemos receber como parâmetro um usuário, porém temos que verificar se o E-mail e senha estão no nosso banco de dados e depois retorna se achou ou se não achou, para verificar dados específicos em um Banco de dados precisamos utilizar um Where. Porém como fazer isso no CodeIgniter? Podemos fazer de duas maneiras simples. 1. Antes de consultar informa o Where; 2. Mudar nosso código para utilizar o get_where, que passamos a tabela e uma array com os dados do Where.
  • 8. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima 1. Informando o Where antes da consulta: public function autentica($usuario){ $this->db->where("email", $usuario["email"]); $this->db->where("senha", $usuario["senha"]); $usuario = $this->db->get("usuarios")->row_array(); return $usuario; }
  • 9. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima 2. Utilizando o get_where: public function autentica($usuario){ $usuario = $this->db->get_where("usuarios", array( "email"=>$usuario["email"], "senha"=>$usuario["senha"]) )->row_array(); return $usuario; }
  • 10. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima Agora nós temos nosso código que verifica se existe um usuário com o E-mail e Senha Informados. Porém, aonde vamos armazenar aquele resultado? Seria legal que depois que localizarmos um usuário criar uma sessão para ele, algo que só o usuário que eu acabei de achar e o servidor tivessem. No CodeIgniter existe uma função chamada userdata, que fica dentro da classe session, para adicionar um valor nesta função, utiliza o set_userdata, mas vamos passar uma Mensagem também, para deixar nosso código mais compreensível para o usuário, e depois Direcionaremos para uma view que exibirá está mensagem. Então nosso código irá ficar semelhante a este:
  • 11. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de LimaRealize um teste, utilizando o seu usuário cadastrado.
  • 12. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima Só que quando vamos testar, ele já cai em um erro.
  • 13. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima Mas espera um momento, nós já vimos este erro em outro slide: A PHP Error was encountered Severity: Notice Message: Undefined property: Login::$session Filename: controllers/login.php Erro de propriedade indefinida? Neste caso, nossa propriedade está correta, mas porque não está carregando? Por um simples e pequeno motivo, esquecemos de carregar a library da session, mas a Session é algo muito importante para todo meu código e eu vou utilizar bastante ela. Então vamos voltar no AutoLoad, e além de carregar o database, iremos carregar a Session automaticamente.
  • 14. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima Mas se eu já fiz o login no sistema, não quero que apareça o formulário para fazer o login Ou o formulário de cadastro novamente, eu quero que apareça apenas os produtos. E se eu estou logado no sistema, eu também quero fazer o Logout. Vamos fazer uma parte de cada vez: 1. Alteraremos a index, para caso estejamos logados, não exibir os formulários; 2. Criar um botão para fazer o logout; 3. Melhorar a visualização da mensagem de “Logado com Sucesso” ou “Login ou Senha inválidas”;
  • 15. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima Começaremos com o mais fácil e rápido, vá na pasta Produtos e no arquivo Index.php, e antes de criar os formulários faça uma verificação utilizando um if. - Mas if o que? Se nós utilizamos o set_userdata, para atribuir um valor no userdata, vamos utiliza-lo Para verificar se existe algum valor “setado” ou não. Para realizar esta verificação fazemos: <?php if($this->session->userdata("usuario_logado")) : ?> E logo após criarmos o ultimo formulário, terminaremos o nosso if: <?php endif ?>
  • 16. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima Agora que fazemos uma verificação para ver se tem algum usuário ativo ou não no sistema, só que falto o botão de deslogar. Para criar este botão, utilizaremos um anchor, que recebe 3 parâmetros, o primeiro é qual a ação dele quando clicado, o segundo é o nome que será exibido e o terceiro é um array que contem as informações dele, como class, id, name e outras Tag de HTML.
  • 17. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima
  • 18. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima Nosso anchor direciona para o login/logout, porém ainda não criamos está função. Vamos no Controller Login e criaremos a função logout, que ela ira retirar o valor do login. public function logout(){ $this->session->unset_userdata("usuario_logado"); }
  • 19. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima Agora nós temos um sistema de Login e Logout de usuários, mas ainda falta melhorar na questão das mensagens, seria legal utilizar alguma função que exibisse a mensagem apenas uma vez e depois desaparecesse. Para isso nós temos a função flashdata, que recebe 2 parâmetros. O Primeiro parâmetro é o nome do flashdata e o segundo é a mensagem que dele. Vamos adicionar um valor no flashdata quando fazemos o login. Para isso retorne a função Autenticar e caso ele ache um usuário, adicione uma mensagem de: “Login realizado com sucesso” E depois, redirecione para a pagina inicial.
  • 20. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima
  • 21. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima Depois de ter criado a mensagem, vamos exibi-la. Vá na pasta Produtos e abra o arquivo Index, e antes da tag h1 Produtos, verifique se tem algum flashdata do tipo “success”, e se tiver vamos exibi-lo.
  • 22. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima Este é o código que deve ser adicionado na Index: <?php if($this->session->flashdata("success")) : ?> <p style="text-align:center;" class="alert alert-success"> <?= $this->session->flashdata("success"); ?> </p> <?php endif ?> Agora temos uma index mais bonita e com uma mensagem mais agradavel.
  • 23. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima Exercicio
  • 24. Implementando o Login e Logout Exibindo mensagens com o FlashData Criado por: Raniere de Lima Crie um flashdata para caso o login ou senha estiverem erradas, e para quando o Logout for realizado.