Ir para conteúdo

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 landerbadi
      Boa tarde pessoal. Estou tentado fazer uma consulta no banco de dados porém estou tendo dificuldades. Tenho uma tabela chamada "itens" com os seguintes campos: id, item, ativo. Nela tem cadastrado vários itens. No campo ativo eu coloco a letra "S" para informar que este item está ativo no sistema. Por exemplo: 1, casa, S 2, mesa, S 3, cama, S 4, moto S 5, rádio O quinto registro "radio" não está ativo no sistema pois não tem um "S" no campo ativo. E outra tabela chamada "produtos" com os seguintes campos (id, item1, item2, item3) com os seguintes registros: 1, casa, mesa, moto 2, mesa, casa, cama 3, rádio, cama, mesa Eu preciso fazer uma busca na tabela produtos da seguinte maneira: Eu escolho um registro na tabela "itens", por exemplo "mesa". Preciso fazer com que o php me liste todos os registros da tabela "produtos" que contenham a palavra "mesa". Até aqui tudo bem eu consigo listar. Estou fazendo assim: <?php $item = "mesa" $sql = mysqli_query($conn, "SELECT * FROM produtos WHERE item1 LIKE '$item' OR item2 LIKE '$item' OR item3 LIKE '$item' LIMIT 10"); while($aux = mysqli_fetch_assoc($sql)) { $id = $aux["id"]; $item1 = $aux["item1"]; $item2 = $aux["item2"]; $item3 = $aux["item3"]; echo $id . " - " . $item1 . ", " . $item2 . ", " $item3 . "<br>"; } ?> O problema é que está listando todos os registros que contém o item mesa. Eu preciso que o php verifique os demais item e me liste somente os registro em que todos os registros estejam ativos no sistema. No exemplo acima ele não deveria listar o registro 3. pois nesse registro contém o item "radio" e este item não está ativo no sistema. Ou seja, o registro "radio" na tabela itens não possui um "S" na coluna "ativo". Alguém sabe como resolver isso?
    • Por ILR master
      Fala galera.
      Espero que todos estejam bem.
      Seguinte: Tenho um arquivo xml onde alguns campos estão com : (dois pontos), como o exemplo abaixo:
       
      <item>
      <title>
      d sa dsad sad sadasdas
      </title>
      <link>
      dsadas dsa sad asd as dsada
      </link>
      <pubDate>sadasdasdsa as</pubDate>
      <dc:creator>
      d sad sad sa ad as das
      </dc:creator>
      </item>
       
      Meu código:
       
      $link = "noticias.xml"; 
      $xml = simplexml_load_file($link); 
      foreach($xml -> channel as $ite) {     
           $titulo = $ite -> item->title;
           $urltitulo = $ite -> item->link;
           print $urltitulo = $ite -> item->dc:creator;
      } //fim do foreach
      ?>
       
      Esse campo dc:creator eu não consigo ler. Como faço?
       
      Agradeço quem puder me ajudar.
       
      Abs
       
       
    • Por First
      Olá a todos!
       
      Eu estou criando um sistema do zero mas estou encontnrando algumas dificuldades e não estou sabendo resolver, então vim recorrer ajuda de vocês.
      Aqui está todo o meu código: https://github.com/PauloJagata/aprendizado/
       
      Eu fiz um sistema de rotas mas só mostra o conteúdo da '/' não sei porque, quando eu tento acessar o register nada muda.
      E eu também quero que se não estiver liberado na rota mostra o erro de 404, mas quando eu tento acessar um link inválido, nada acontece.
      Alguém pode me ajudar com isso? E se tiver algumas sugestão para melhoria do código também estou aceitando.
       
       
      Desde já, obrigado.
    • Por landerbadi
      Olá pessoal, boa tarde
       
      Tenho uma tabela chamada "produtos" com os seguintes campos (id, produto) e outra tabela chamada "itens" com os seguintes campos (id, prod_01, prod_02, prod_03, prod_04).
       
      Na tabela produtos eu tenho cadastrado os seguintes produtos: laranja, maçã, uva, goiaba, arroz, feijão, macarrão, etc.
       
      Na tabela itens eu tenho cadastrado os itens da seguinte maneira:
       
      1, laranja, uva, arroz, feijão;
      2, maçã, macarrão, goiaba, uva;
      3, arroz, feijão, maçã, azeite
       
      Meu problema é o seguinte: 
      Eu escolho um produto da tabela "produtos", por exemplo "uva".  Preciso fazer uma consulta na tabela "itens" para ser listado todos os registros que contenham o produto "uva" e que todos os demais produtos estejam cadastrados na tabela "produtos".
       
      No exemplo acima seria listado apenas dois registros, pois o terceiro registro não contém o produto "uva". 
       
      Alguém pode me ajudar? Pois estou quebrando a cabeça a vários dias e não consigo achar uma solução.
    • Por landerbadi
      Boa tarde pessoal. Estou tentado fazer uma consulta no banco de dados porém estou tendo dificuldades. Tenho uma tabela chamada "itens" com os seguintes campos: id, item, plural, ativo. Nela tem cadastrado vários itens e seu respectivo plural. No campo ativo eu coloco a letra "S" para informar que esta palavra está ativa no sistema. Por exemplo: 1, casa, casas, S 2, mesa, mesas, S 3, cama, camas, S 4, moto, motos, S 5, rádio, rádios O quinto registro "radio" não está ativo no sistema pois não tem um "S" no campo ativo. E outra tabela chamada "variações" com os seguintes campos (id, item1, item2, item3) com os seguintes registros: 1, casa, camas, moto 2, mesas, casas, radio 3, rádio, cama, mesa Eu preciso fazer uma busca na tabela variações da seguinte maneira: Eu escolho um registro na tabela "itens", por exemplo "casa". Preciso fazer com que o php me liste todos os registros da tabela "variações" que contenham a palavra "casa". Porém se tiver algum registro com a palavra "casas" também tem que ser listado. Neste caso ele irá encontrar dois registros. Agora eu preciso que o php verifique os demais itens e faça a listagem apenas dos item que estão ativos (que contenham um "S" no campo ativo. Neste caso ele irá encontrar apenas um registro, pois o segundo registro contém a palavra "rádio". E "rádio" não está ativo na tabela itens. Como faço isso?
×

Informação importante

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