Ir para conteúdo

POWERED BY:

Arquivado

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

  • 0
Alexandre Athayde

A sessão não está guardando valor em PHP

Pergunta

Bom dia galera, tenho conhecimento em java web porém comecei a aprender PHP e estou desenvolvendo uma aplicação web para um setor de minha empresa que no momento encontra-se toda manual a suas anotações. Estou utilizando o serviço de hospedagem 000webhost para testar toda a aplicação. Na tela de login o funcionário efetua o mesmo e logo em seguida é redirecionado para uma pagina index.php, porem quando é feito este redirecionamento creio que as informações que estão na sessão é perdida., porque não estou conseguindo recuperar o mesmo.

Creio que não há nenhum problema no meu código de validação e funcionário, segue o código abaixo:

 

<!DOCTYPE html>
<!--
To change this license header, choose License Headers in Project Properties.
To change this template file, choose Tools | Templates
and open the template in the editor.
-->
<!-- Incluindo a  conexão com o banco de dados MySQL -->
<?php
include './config/conexao.php';

if (isset($_POST['re']) && strlen($_POST['re']) > 0) {
    if (!isset($_SESSION)) {
        session_start();
        $_SESSION['re'] = $mysqli->escape_string($_POST['re']);
        $_SESSION['senha'] = $_POST['senha'];

        $sql_code = "SELECT id, nome, turno, re, senha FROM tb_funcionario WHERE re = '$_SESSION[re]'";
        $sql_query = $mysqli->query($sql_code) or die($mysqli->error); // Executando  a consulta no banco MySQL
        $dados = $sql_query->fetch_assoc(); //Pegando os dados
        $total = $sql_query->num_rows; // Recebendo o total de consultas encontradas

        if ($total == 0) {
            $erro[] = "Este re não pertence a nenhum funcionário.";
        } else {
            if ($dados['senha'] == $_SESSION['senha']) {
                $_SESSION['logado']     =   $dados['id'];
                $_SESSION['nome']       =   $dados['nome'];
                $_SESSION['turno']      =   $dados['turno'];
                $_SESSION['re']         =   $dados['re'];
                
            } else {
                $erro[] = "Senha incorreta!";
            }
        }
    }
    if (count($erro) == 0 || !isset($erro)) {
        echo "<script>location.href='./funcionario/index.php';</script>";
    }
    
}
?> 
<html>
    <head>
        <meta charset="UTF-8">
        <title>CRF - Controle de Reciclagem Femsa</title>
        <link rel="stylesheet" href="css/style.css">
    </head>
    <body>
        <!-- Mostrando erro no Front-end -->
        <?php
            if(count($erro) > 0){
                foreach ($erro as $msg){
                    echo "<p>$msg</p>";
                }
            }
        ?>
        <link rel="stylesheet" href="http://maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css"/>
        <div class="main">
            <div class="container">
                <div class="middle">
                    <div id="login">
                        <form method="POST" action="">
                            <fieldset class="clearfix">
                                <p ><span class="fa fa-user"></span><input type="text" value="<?php echo $_SESSION['re']; ?>" name="re" Placeholder="RE" required></p> <!-- JS because of IE support; better: placeholder="Username" -->
                                <p><span class="fa fa-lock"></span><input type="password"  name="senha" Placeholder="Entre com a senha!" required></p> <!-- JS because of IE support; better: placeholder="Password" -->
                                <div>
                                    <span style="width:48%; text-align:left;  display: inline-block;"><a class="small-text" href="recuperaSenha.php">Esqueceu sua senha?</a></span>
                                    <span style="width:50%; text-align:right;  display: inline-block;"><input type="submit" value="Acessar"></span>
                                </div>
                            </fieldset>
                            <div class="clearfix"></div>
                        </form>
                        <div class="clearfix"></div>
                    </div> <!-- end login -->
                    <div class="logo">
                        <img src="img/logo REC.png">
                        <div class="clearfix"></div>
                    </div>
                </div>
            </div>
        </div>
    </body>
</html>

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

15 respostas a esta questão

Recommended Posts

11 horas atrás, jdsdias disse:

Você está adicionando session_start(); em todas as páginas que precisam dessas sessions? Veja no manual do php um exemplo utilizando sessions: http://php.net/manual/pt_BR/function.session-start.php

 

Sim estou, mesmo assim não está funcionando.

 

Exemplo:

session_start();

$nome = $_SESSION['nome'];

Compartilhar este post


Link para o post
Compartilhar em outros sites
19 minutos atrás, jdsdias disse:

Fiz um teste com o mesmo script que você utilizou e a session é guardada normalmente. Acredito que o problema deve estar no seu servidor de hospedagem.

 

Bom dia. Tem alguma ideia, adicionar algum arquivo no servidor? Estive olhando o servidor e não consta nenhum arquivo nele de configuração.

Compartilhar este post


Link para o post
Compartilhar em outros sites
Agora, jdsdias disse:

Crie um arquivo .php e adicione essas linhas nele:


<?php
	phpinfo();
?>

Posta a saída desse comando aqui relacionada a parte de sessões

 Não entendei, este novo arquivo coloco ele  sozinho no servidor?

Compartilhar este post


Link para o post
Compartilhar em outros sites

Acho que peguei o erro fiz um teste em outro servidor e deu essa mensagem: Warning: session_start(): Cannot send session cache limiter - headers already sent

 

Tente colocar o session_start no topo do código, em cima do <!DOCTYPE html>

 

Ficaria assim:

<?php
include './config/conexao.php';

if (isset($_POST['re']) && strlen($_POST['re']) > 0) {
    if (!isset($_SESSION)) {
        session_start();
        $_SESSION['re'] = $mysqli->escape_string($_POST['re']);
        $_SESSION['senha'] = $_POST['senha'];

...

<!DOCTYPE html>
<!--
To change this license header, choose License Headers in Project Properties.
To change this template file, choose Tools | Templates
and open the template in the editor.
-->

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
13 minutos atrás, jdsdias disse:

Acho que peguei o erro fiz um teste em outro servidor e deu essa mensagem: Warning: session_start(): Cannot send session cache limiter - headers already sent

 

Tente colocar o session_start no topo do código, em cima do <!DOCTYPE html>

 

Ficaria assim:


<?php
include './config/conexao.php';

if (isset($_POST['re']) && strlen($_POST['re']) > 0) {
    if (!isset($_SESSION)) {
        session_start();
        $_SESSION['re'] = $mysqli->escape_string($_POST['re']);
        $_SESSION['senha'] = $_POST['senha'];

...

<!DOCTYPE html>
<!--
To change this license header, choose License Headers in Project Properties.
To change this template file, choose Tools | Templates
and open the template in the editor.
-->

 

 

 

Infelizmente fiz dessa forma e continua a mesma situação.

 

<!-- Incluindo a  conexão com o banco de dados MySQL -->
<?php
include './config/conexao.php';

if (isset($_POST['re']) && strlen($_POST['re']) > 0) {
    if (!isset($_SESSION)) {
        session_start();
        $_SESSION['re'] = $mysqli->escape_string($_POST['re']);
        $_SESSION['senha'] = $_POST['senha'];

        $sql_code = "SELECT id, nome, turno, re, senha FROM tb_funcionario WHERE re = '$_SESSION[re]'";
        $sql_query = $mysqli->query($sql_code) or die($mysqli->error); // Executando  a consulta no banco MySQL
        $dados = $sql_query->fetch_assoc(); //Pegando os dados
        $total = $sql_query->num_rows; // Recebendo o total de consultas encontradas

        if ($total == 0) {
            $erro[] = "Este re não pertence a nenhum funcionário.";
        } else {
            if ($dados['senha'] == $_SESSION['senha']) {
                $_SESSION['logado']     =   $dados['id'];
                $_SESSION['nome']       =   $dados['nome'];
                $_SESSION['turno']      =   $dados['turno'];
                $_SESSION['re']         =   $dados['re'];
                
            } else {
                $erro[] = "Senha incorreta!";
            }
        }
    }
    if (count($erro) == 0 || !isset($erro)) {
echo "<script>document.location.replace('./funcionario/index.php');</script>";        
//echo "<script>location.href='./funcionario/index.php';</script>";
    }
    
}
?>
<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title>CRF - Controle de Reciclagem Femsa</title>
        <link rel="stylesheet" href="css/style.css">
    </head>
    <body>
        <!-- Mostrando erro no Front-end -->
        <?php
            if(count($erro) > 0){
                foreach ($erro as $msg){
                    echo "<p>$msg</p>";
                }
            }
        ?>
        <link rel="stylesheet" href="http://maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css"/>
        <div class="main">
            <div class="container">
                <div class="middle">
                    <div id="login">
                        <form method="POST" action="">
                            <fieldset class="clearfix">
                                <p ><span class="fa fa-user"></span><input type="text" value="<?php echo $_SESSION['re']; ?>" name="re" Placeholder="RE" required></p> <!-- JS because of IE support; better: placeholder="Username" -->
                                <p><span class="fa fa-lock"></span><input type="password"  name="senha" Placeholder="Entre com a senha!" required></p> <!-- JS because of IE support; better: placeholder="Password" -->
                                <div>
                                    <span style="width:48%; text-align:left;  display: inline-block;"><a class="small-text" href="recuperaSenha.php">Esqueceu sua senha?</a></span>
                                    <span style="width:50%; text-align:right;  display: inline-block;"><input type="submit" value="Acessar"></span>
                                </div>
                            </fieldset>
                            <div class="clearfix"></div>
                        </form>
                        <div class="clearfix"></div>
                    </div> <!-- end login -->
                    <div class="logo">
                        <img src="img/logo REC.png">
                        <div class="clearfix"></div>
                    </div>
                    
                    
                    
                </div>
            </div>
        </div>
    </body>
</html>

menuF.php

 


<?php
    session_start();
    $nome = $_SESSION['nome'];
    $logado = $_SESSION['logado'];
?>
<!DOCTYPE>
<html lang="pt-br">
<head>
    <meta charset="utf-8"/>
    <title></title>
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <!-- BOOTSTRAP STYLES-->
    <link href="../css/bootstrap.css" rel="stylesheet" />
    <!-- FONTAWESOME STYLES-->
    <link href="../css/font-awesome.css" rel="stylesheet" />
    <!-- CUSTOM STYLES-->
    <link href="../css/custom.css" rel="stylesheet" />
    <!-- GOOGLE FONTS-->
    <link href='http://fonts.googleapis.com/css?family=Open+Sans' rel='stylesheet' type='text/css' />
    <script type="text/javascript">
        function showTime(){
            var time = new Date();
            var hora = time.getHours();
            var minuto = time.getMinutes();
            var segundo = time.getSeconds();

            if(hora < 10) hora = "0" + hora;
            if(minuto < 10) minuto = "0" + minuto;
            if(segundo < 10) segundo = "0" + segundo;
            var tempo = hora + ":" + minuto + ":" + segundo;

            document.getElementById("timer").innerHTML =  tempo;
        }
        function initTime(){
            setInterval(showTime, 1000);
        }
    </script>
</head>
<body onload="initTime();">
<div id="wrapper">
    <nav class="navbar navbar-default navbar-cls-top " role="navigation" style="margin-bottom: 0">
        <div class="navbar-header">
            <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".sidebar-collapse">
                <span class="sr-only">Toggle navigation</span>
                <span class="icon-bar"></span>
                <span class="icon-bar"></span>
                <span class="icon-bar"></span>
            </button>
            <a class="navbar-brand" href="index.jsp">CRF 1.0v</a>
        </div>
        <div style="color: white;
padding: 15px 50px 5px 50px;
float: right;
font-size: 16px;"> Ultimo acesso : 30 May 2014 &nbsp; <a href="../config/logout.php" class="btn btn-danger square-btn-adjust">Sair</a> </div>
    </nav>
    <!-- /. NAV TOP  -->
    <nav class="navbar-default navbar-side" role="navigation">
        <div class="sidebar-collapse">
            <ul class="nav" id="main-menu">
                <li class="text-center">

                    <h1><span id="timer"></span></h1>
                    <p>Nome: <?php echo $nome; ?></p>
                    <p>logado: <?php echo $logado; ?></p>
                </li>


                <li>
                    <a  href="cadChecklist.php"><i class="fa fa-dashboard fa-3x"></i> Checklist Prensa</a>
                </li>
                <li>
                    <a  href="cadFardo.php"><i class="fa fa-edit fa-3x"></i> Lançar Fardo</a>
                </li>
                
                
            </ul>

        </div>

    </nav>
    <!-- /. NAV SIDE  -->

    <!-- /. WRAPPER  -->
    <!-- SCRIPTS -AT THE BOTOM TO REDUCE THE LOAD TIME-->
    <!-- JQUERY SCRIPTS -->
    <script src="../js/jquery-1.10.2.js"></script>
    <!-- BOOTSTRAP SCRIPTS -->
    <script src="../js/bootstrap.min.js"></script>
    <!-- METISMENU SCRIPTS -->
    <script src="../js/jquery.metisMenu.js"></script>
    <!-- CUSTOM SCRIPTS -->
    <script src="../js/custom.js"></script>

</body>
</html>

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
4 minutos atrás, jdsdias disse:

<!-- Incluindo a  conexão com o banco de dados MySQL -->

 

Retire esse trecho do código do topo também, começe o código com as tags  do php <?php

Também não, continua session vazia.

Compartilhar este post


Link para o post
Compartilhar em outros sites
8 minutos atrás, jdsdias disse:

<!-- Incluindo a  conexão com o banco de dados MySQL -->

 

Retire esse trecho do código do topo também, começe o código com as tags  do php <?php

Consegui cara, tive que separar a session_star() nos dois documento

<?php

session_start();

?>

 

<?php

aqui entra código da aplicação

?>

 

Muito obrigado pela força e dedicar um pouco do seu tempo para me ajudar amigo valeu.

Compartilhar este post


Link para o post
Compartilhar em outros sites

De nada. Mas testa com o código assim também:

<?php
session_start();
include './config/conexao.php';

if (isset($_POST['re']) && strlen($_POST['re']) > 0) {
    if (!isset($_SESSION)) {        
        $_SESSION['re'] = $mysqli->escape_string($_POST['re']);
        $_SESSION['senha'] = $_POST['senha'];

Acredito que nem precisa separar, somente manter o session_start no topo do documento antes de qualquer outro código.

Compartilhar este post


Link para o post
Compartilhar em outros sites
5 minutos atrás, jdsdias disse:

De nada. Mas testa com o código assim também:


<?php
session_start();
include './config/conexao.php';

if (isset($_POST['re']) && strlen($_POST['re']) > 0) {
    if (!isset($_SESSION)) {        
        $_SESSION['re'] = $mysqli->escape_string($_POST['re']);
        $_SESSION['senha'] = $_POST['senha'];

Acredito que nem precisa separar, somente manter o session_start no topo do documento antes de qualquer outro código.

Sim desta forme também funciona, obrigado.

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.