Ir para conteúdo

POWERED BY:

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

Pellegrini2106

Problema ao restringir uma página.

Recommended Posts

Olá amigos do php estou com uma duvida com relação ao código em MVC que restringi a página com sessões depois que o usuário for logado no sistema.

Minha duvida e o seguinte, dependendo de cada usuário que será logado ele irá ser reportado para sua respectiva página é lá queria que ele se tornasse restrita e imprimiria uma mensagem na tela dando boas vindas ao perfil tal e usuário tal, mas não sei de que forma irei fazer esta sessão, pois eu coloquei para carregar a sessão dentro do switch case de cada pagina carregada pelo perfil mais só que ele aparece na mesma pagina login e não e isso que eu queria. Queria q ele aparece na outra pagina já logada dizendo Olá perfil tal e o usuário tal correspondente àquela página.

modelo : Usuario.php

<?php

class usuario {

    private $id_usuario;
    private $nome;
    private $email;
    private $perfil;
    private $usuario;
    private $senha;

    public function getId_usuario() {
        return $this->id_usuario;
    }

    public function getNome() {
        return $this->nome;
    }

    public function getEmail() {
        return $this->email;
    }

    public function getPerfil() {
        return $this->perfil;
    }

    public function getUsuario() {
        return $this->usuario;
    }

    public function getSenha() {
        return $this->senha;
    }

    public function setId_usuario($id_usuario) {
        $this->id_usuario = $id_usuario;
        return $this;
    }

    public function setNome($nome) {
        $this->nome = $nome;
        return $this;
    }

    public function setEmail($email) {
        $this->email = $email;
        return $this;
    }

    public function setPerfil($perfil) {
        $this->perfil = $perfil;
        return $this;
    }

    public function setUsuario($usuario) {
        $this->usuario = $usuario;
        return $this;
    }

    public function setSenha($senha) {
        $this->senha = $senha;
        return $this;
    }
}

DAO : DAOLogar.php

<?php

class daoLogar {

    private $cnx;

    function __construct() {

        try {
            $this->cnx = new PDO('mysql:host=localhost;port=3306;dbname=usuarios', 'root', '');
        } catch (PDOException $ex) {
            echo '<div class="alert-danger">' . $ex->getMessage() . '</div>';
        }
    }

    public function verificarLogin(usuario $Usuario) {

        $array = array();

        try {
            $sql = "SELECT * FROM tbusuario WHERE usuario =? AND senha =? LIMIT 1";
            $campo = $this->cnx->prepare($sql);
            $campo->bindParam(1, $Usuario->getUsuario(), PDO::PARAM_STR);
            $campo->bindParam(2, $Usuario->getSenha(), PDO::PARAM_STR);
            $campo->execute();
            while ($row = $campo->fetch(PDO::FETCH_ASSOC)) {
                $array[$row['id_usuario']]['id_usuario'] = $row['id_usuario'];
                $array[$row['id_usuario']]['perfil'] = $row['perfil'];
                $array[$row['id_usuario']]['usuario'] = $row['usuario'];
                $array[$row['id_usuario']]['senha'] = $row['senha'];
            }
            return $array;
            
        } catch (PDOException $ex) {
            echo '<div class="alert-danger">' . $ex->getMessage() . '</div>';
        }
    }

}

Controle: controleLogar.php

<?php

require_once 'modelo/usuario.php';
require_once 'dao/daoLogar.php';

class controleLogar {

    protected $ObjUsuario;
    protected $ObjDaoLogar;
    protected $ctl;

    public function __construct() {

        $this->ObjUsuario = new usuario();
        $this->ObjDaoLogar = new daoLogar();
    }

    public function ctlVerificarLogin() {

        if (isset($_POST["btnEntrar"])) {

            $this->ObjUsuario->setUsuario($_POST['txtusuario']);
            $this->ObjUsuario->setSenha($_POST['txtsenha']);
            $this->ctl = $this->ObjDaoLogar->verificarLogin($this->ObjUsuario);

            if (empty($_POST["txtusuario"]) || (empty($_POST["txtsenha"]))) {

                echo '<div class="alert-danger"> Por Favor Preencha o Campo em Branco!!!!!!</div>';
            } else if ($this->ObjUsuario->getUsuario() == 'admin' || $this->ObjUsuario->getSenha() == 'admin') {

                echo '<div class="alert-admMaster">Administrador Master Logado com Sucesso!!!!!!</div>';

                echo "<meta HTTP-EQUIV='refresh' CONTENT='8;URL=visaoAdministrador/visaoCadastrarUsuario.php'>";
            } else if (!$this->ctl) {

                echo '<div class="alert-warning">Usuário e Senha estão Incorretas!!!!!!</div>';
            } else {

                foreach ($this->ctl as $key => $value) {

                    switch ($value['perfil']) {

                        case 'Administrador':
                        
                        foreach($this->ctl as $key =>$value){
                          session_start();
                          echo 'Olá'. $_SESSION['perfil'] = $value['perfil'].' '. $_SESSION['usuario'] = $value['usuario'];
                        }

                            echo '<div class="alert-administrador">Administrador Logado com Sucesso!!!!!!</div>';

                            echo "<meta HTTP-EQUIV='refresh' CONTENT='8;URL=visaoAdministrador/visaoMenuAdministrador.php'>"; //será pagina restrita.

                            break;

                        case 'Cliente':

                            echo '<div class="alert-cliente">Cliente Logado com Sucesso!!!!!!</div>';

                            echo "<meta HTTP-EQUIV='refresh' CONTENT='8;URL=visaoCliente/visaoMenuCliente.php'>";//será pagina restrita.

                            break;

                        case 'Socio':

                            echo '<div class="alert-socio">Socio Logado com Sucesso!!!!!!</div>';

                            echo "<meta HTTP-EQUIV='refresh' CONTENT='8;URL=visaoSocio/visaoMenuSocio.php'>";//será pagina restrita.

                            break;
                    }
                }
            }
        }
    }

}
Visao: VisaoLogar.php

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title>PRINCIPAL:</title>
        <link rel="stylesheet" type="text/css" href="css/style.css">
        <link rel="stylesheet" type="text/css" href="css/alerta.css">
        <link rel="stylesheet" type="text/css" href="css/bootstrap.css">
        <link rel="stylesheet" type="text/css" href="css/bootstrap.min.css">
        <script language="javascript" type="text/javascript" src="js/JQuery.mim.js"></script>
        <script language="javascript" type="text/javascript" src="js/fechar.js"></script>
        <script language="javascript" type="text/javascript" src="js/bootstrap.js"></script>
    </head>
    <body>
        <div class="topo">
            <div class="letras">
                <div id="m">
                    <?php
                    require_once 'controle/controleLogar.php';
                    $cs = new controleLogar();
                     $cs->ctlVerificarLogin();
                     ?>
                </div>
            </div>
        </div>
        <div class="cabecalho">
            <form method="post" class="letras alinhaLogin">
                <table width="688" border="0">
                    <tr>
                        <td width="58" align="center" valign="middle">Usuário:</td>
                        <td width="144" align="center" valign="middle"><input name="txtusuario" type="text" size="40" placeholder="Digite Usuário:" class="form-control"></td>
                        <td width="46" align="center" valign="middle">Senha:</td>
                        <td width="144" align="center" valign="middle"><input name="txtsenha" type="password" size="10"  placeholder="Digite Senha:" class="form-control"></td>
                        <td width="94" align="center" valign="middle"><input name="btnEntrar" type="submit" class="btn btn-info" value="Entrar:"> </td>
                    </tr>
                </table>
            </form>
        </div>
     </body>
</html>

 

 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Correto é o Controller SOMENTE redirecionar o usuário, de acordo com as permissões e não fazer o papel da Views.  

 

 

echo "<meta HTTP-EQUIV='refresh' CONTENT='8;URL=visaoSocio/visaoMenuSocio.php'>";//será pagina restrita.

:open_mouth: Oito segundo de espera pra nada, se coloque no lugar do usuário. 


Troque isso por http://php.net/manual/pt_BR/function.header.php

Compartilhar este post


Link para o post
Compartilhar em outros sites

Williams eu não coloquei um header location pq simplesmente possuo uma mensagem antes  avisando que seu usuário  foi logado com sucesso e depois ele reportaria ele para a pagina restrita que ele foi registrada pelo usuário através do perfil escolhido, mas agora esse não é o problema a resolver  amigo eu queria somente quando entrar - se  em alguma pagina depois de logado ela se torne restrita utilizando sessões.:thumbsup:

Compartilhar este post


Link para o post
Compartilhar em outros sites

Cara, veja bem, enquanto você não entender as camadas do MVC, qualquer coisa simples será um problemão a se resolver!
 

Citar

 

View

Simples: a camada de interação com o usuário. Ela apenas faz a  exibição dos dados, sendo ela por meio de um html ou xml.

 

 


Recomendo a leitura.

https://tableless.com.br/mvc-afinal-e-o-que/

Mas em todo caso, faça estas validações de sessões em um construtor

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por violin101
      Caros amigos, saudações.
       
      Por favor, me permita tirar uma dúvida com os amigos.

      Tenho um Formulário onde o Usuário digita todos os Dados necessários.

      Minha dúvida:
      --> como faço após o usuário digitar os dados e salvar, o Sistema chamar uma Modal ou mensagem perguntando se deseja imprimir agora ?

      Grato,
       
      Cesar
    • Por Carcleo
      Tenho uma abela de usuarios e uma tabela de administradores e clientes.
      Gostaria de uma ajuda para implementar um cadastro
       
      users -> name, login, passord (pronta) admins -> user_id, registratiom, etc.. client -> user_id, registratiom, etc...
      Queria ajuda para extender de user as classes Admin e Client
      Olhem como estáAdmin
      <?php namespace App\Models; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Model; class Admin extends User {     use HasFactory;            protected $fillable = [         'name',         'email',         'password',         'registration'     ];      private string $registration;     public function create(         string $name,          string $email,          string $password,         string $registration     )     {         //parent::create(['name'=>$name, 'email'=>$email, 'password'=>$password]);         parent::$name = $name;         parent::$email = $email;         parent::$password = $password;         $this->registration = $registration;     } } User
      <?php namespace App\Models; // use Illuminate\Contracts\Auth\MustVerifyEmail; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Foundation\Auth\User as Authenticatable; use Illuminate\Notifications\Notifiable; use Illuminate\Database\Eloquent\Relations\BelongsToMany; class User extends Authenticatable {     /** @use HasFactory<\Database\Factories\UserFactory> */     use HasFactory, Notifiable;     static string $name;     static string $email;     static string $password;     /**      * The attributes that are mass assignable.      *      * @var list<string>      */     protected $fillable = [         'name',         'email',         'password',     ];          /**      * The attributes that should be hidden for serialization.      *      * @var list<string>      */     protected $hidden = [         'remember_token',     ];     /**      * Get the attributes that should be cast.      *      * @return array<string, string>      */     protected function casts(): array     {         return [             'email_verified_at' => 'datetime',             'password' => 'hashed',         ];     }          public function roles() : BelongsToMany {         return $this->belongsToMany(Role::class);     }       public function hasHole(Array $roleName): bool     {                 foreach ($this->roles as $role) {             if ($role->name === $roleName) {                 return true;             }         }         return false;     }         public function hasHoles(Array $rolesName): bool     {                 foreach ($this->roles as $role) {             foreach ($rolesName as $rolee) {             if ($role->name === $rolee) {                 return true;             }          }         }         return false;     }         public function hasAbility(string $ability): bool     {         foreach ($this->roles as $role) {             if ($role->abilities->contains('name', $ability)) {                 return true;             }         }         return false;     }     } Como gravar um Admin na tabela admins sendo que ele é um User por extensão?
      Tentei assim mas é claro que está errado...
      public function store(Request $request, Admin $adminModel) {         $dados = $request->validate([             "name" => "required",             "email" => "required|email",             "password" => "required",             "registration" => "required"         ]);         $dados["password"] =  Hash::make($dados["password"]);                  $admin = Admin::where("registration",  $dados["registration"])->first();                  if ($admin)              return                    redirect()->route("admin.new")                             ->withErrors([                                 'fail' => 'Administrador já cadastrados<br>, favor verificar!'                   ]);                            $newAdmin = $adminModel->create(                                    $dados['name'],                                    $dados['email'],                                    $dados['password'],                                    $dados['registration']                                 );         dd($newAdmin);         $adminModel->save();         //$adminModel::create($admin);                  return redirect()->route("admin.new")->with("success",'Cadastrado com sucesso');     }  
    • Por violin101
      Caros amigos, saudações.
       
      Gostaria de tirar uma dúvida com os amigos, referente a PDV.
       
      Estou escrevendo um Sistema com Ponto de Vendas, a minha dúvida é o seguinte, referente ao procedimento mais correto.

      Conforme o caixa vai efetuando a venda, o Sistema de PDV já realiza:
      a baixa direto dos produtos no estoque
      ou
      somente após concretizar a venda o sistema baixa os produtos do estoque ?
       
      Grato,
       
      Cesar
       
    • Por violin101
      Caros amigos do grupo, saudações e um feliz 2025.
       
      Estou com uma pequena dúvida referente a Teclas de Atalho.

      Quando o Caps Lock está ativado o Comando da Tecla de Atalho não funciona.
      ou seja:
      se estiver para letra minúscula ====> funciona
      se estiver para letra maiúscula ====> não funciona
       
      Como consigo evitar essa falha, tanto para Letra Maiúscula quanto Minúscula ?

      o Código está assim:
      document.addEventListener( 'keydown', evt => { if (!evt.ctrlKey || evt.key !== 'r' ) return;// Não é Ctrl+r, portanto interrompemos o script evt.preventDefault(); });  
      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Por favor, poderiam me ajudar.

      Estou com a seguinte dúvida:
      --> como faço para para implementar o input código do produto, para quando o usuário digitar o ID o sistema espera de 1s a 2s, sem ter que pressionar a tecla ENTER.

      exemplo:
      código   ----   descrição
           1       -----   produto_A
       
      Grato,
       
      Cesar
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.