Ir para conteúdo

POWERED BY:

Arquivado

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

jeanzinsousa

Dúvida com SESSION no PHP

Recommended Posts

Salve, galera!

 

to com um problema/dúvida

 

estou criando um arquivo para verificar sessão no sistema que estou criando. Neste arquivo ele irá verificar se existe sessão de usuário iniciada caso não tenha ele volta pra página de login.

porém ai começa o problema/dúvida

 

Quando coloco na página como esta abaixo:

 

pag_inicial.php

 

session_start();
    
    if(!isset($_SESSION['id_usuario'])){
        
        $_SESSION['tipo_msg'] = "danger";
        $_SESSION['msg'] = "Você precisa logar no sistema!";
        header("Location:index.php");
    }

 

ele redireciona pra tela de login é exibe a mensagem normalmente. tudo mil maravilhas

 

agora se eu criar o arquivo sessao.php é colocar no lugar ele redireciona mas não manda a mensagem. Ou seja ele acessa o arquivo verifica a condição só não faz o envio da nova sessao de mensagem no index.php alguém sabe porque?

Compartilhar este post


Link para o post
Compartilhar em outros sites

Ficou confuso. Pelo seu texto são 3 páginas distintas:
1-) página de login. Seria login.php ?

2-) página index.php

3-) pag_inicial.php
e você ainda fala em tela de login.

 

1 hora atrás, jeanzinsousa disse:

agora se eu criar o arquivo sessao.php é colocar no lugar...

 

colocar arquivo sessão.php no lugar? que lugar? com include?

 

Por favor esclareça melhor.

Compartilhar este post


Link para o post
Compartilhar em outros sites
9 horas atrás, Maujor disse:

Ficou confuso. Pelo seu texto são 3 páginas distintas:
1-) página de login. Seria login.php ?

2-) página index.php

3-) pag_inicial.php
e você ainda fala em tela de login.

 

 

colocar arquivo sessão.php no lugar? que lugar? com include?

 

Por favor esclareça melhor.

 

exatamente. quando coloco no a verificação em um arquivo e incluo na pag_inicial.php ele retorna pro index.php(que seria a pagina inicial do sistema que contem a tela de login pro usuário digitar a senha.)

 

ou seja.

 

assim funciona:

pag_inicial.php

 

session_start();
    
    if(!isset($_SESSION['id_usuario'])){
        
        $_SESSION['tipo_msg'] = "danger";
        $_SESSION['msg'] = "Você precisa logar no sistema!";
        header("Location:index.php");
    }

 

assim não funciona:

 

session_start();
    
include 'verifica.php'

?>

 

onde no arquivo verifica contém o script para verificar a sessão do usuário. ele direciona para o index.php, mas não manda a mensagem

 

entendeu?

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Eu nunca vi na minha vida usar validação de SESSION em include, e nunca usei pelo menos, não sei te informar se essa validação é TRUE. Aconselho à utilizar o padrão mesmo!

 

session_start();

if(!isset($_SESSION['id_usuario'])){
       
	$_SESSION['tipo_msg'] = "danger";
    $_SESSION['msg'] = "Você precisa logar no sistema!";
    header("Location:index.php");
}

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
1 hora atrás, Jesse&Francinete disse:

Eu nunca vi na minha vida usar validação de SESSION em include, e nunca usei pelo menos, não sei te informar se essa validação é TRUE. Aconselho à utilizar o padrão mesmo!

 


session_start();

if(!isset($_SESSION['id_usuario'])){
       
	$_SESSION['tipo_msg'] = "danger";
    $_SESSION['msg'] = "Você precisa logar no sistema!";
    header("Location:index.php");
}

 

 

eu uso é funciona tanto com o include quanto o require. o problema é que a $_SESSION['msg'] e $_SESSION['tipo_msg'] não entendi o porque. ele redireciona mais não faz o session. to querendo usar o arquivo porque caso eu queria mudar a msg ou alguma outra implementação não vou precisar ir página a página. mas se não tiver jeito. fazer o que.

 

obrigado pela ajuda.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Você pode verificar que a SESSION['tipo_msg'] NÃO existe:

 

if (!isset($_SESSION['tipo_msg'])){
$_SESSION['tipo_msg'] = "danger";
}

 

E da mesma forma fazer com a outra.

Compartilhar este post


Link para o post
Compartilhar em outros sites
29 minutos atrás, Jesse&Francinete disse:

Você pode verificar que a SESSION['tipo_msg'] NÃO existe:

 


if (!isset($_SESSION['tipo_msg'])){
$_SESSION['tipo_msg'] = "danger";
}

 

E da mesma forma fazer com a outra.

descobri o problema eu tinha um no final do codigo  o local que recebe a $_session['msg'] por isso não enviava pro index.php

 

quando removi funcionou. ta 100% agora.

Compartilhar este post


Link para o post
Compartilhar em outros sites

@jeanzinsousa

Inicialmente umas dicas de postagem no fórum.
1-) Use citar, somente se for importante para esclarecer um ponto do seu post.
No seu post você citou o que eu já havia dito, sem necessidade alguma. Bastava ter escrito @Maujor

e mais ainda, transcreveu código  que já havia postado anteriormente, bastava ter escrito: conforme código que postei anteriormente.

 

E, agora umas considerações sobre sua dúvida.

5 horas atrás, jeanzinsousa disse:

exatamente. quando coloco no a verificação em ...

-o que significa "quando coloco no a verificação"?

 

5 horas atrás, jeanzinsousa disse:

...incluo na pag_inicial.php ele retorna pro index.php(que seria a pagina inicial do sistema que contem a tela de login pro usuário digitar a senha.)

pag-inicial.php e index.php(que seria a pagina inicial do sistema..,?

Tem duas páginas iniciais?

 

5 horas atrás, jeanzinsousa disse:

onde no arquivo verifica contém o script para verificar a sessão do usuário.

arquivo verifica? tem mais um arquivo?

 

1 hora atrás, jeanzinsousa disse:

...descobri o problema eu tinha um no final do codigo...

tinha um no final do codigo?

Descobriu? Parabéns! 
O fórum é para uma comunidade e quando outros tiverem o mesmo problema e depois de uma busca vierem parar nessa thread
para conhecer a solução vão ficar frustados, pois só você conhece a solução.
Por favor, poste qual foi a solução, pois eu tinha um no final do codigo é indecifrável.

 

5 horas atrás, jeanzinsousa disse:

entendeu?

 

Sinceramente? Não!

 

Importante: Meu objetivo ao te passar essas dicas e considerações é meramente didático, pois como pode-se notar, você é novo no fórum (9 posts). Assim, considere somente este aspecto didático e procure observar como os moderadores do fórum e os não novatos respondem às dúvidas.

Compartilhar este post


Link para o post
Compartilhar em outros sites

@Maujor agradeço suas dicas foi a primeira vez que postei aqui, geralmente uso só como pesquisa. consegui resolver o meu problema. to até procurando pra fechar o tópico ou marcar como resolvido é não achei.

 

22 horas atrás, Maujor disse:

Descobriu? Parabéns! 
O fórum é para uma comunidade e quando outros tiverem o mesmo problema e depois de uma busca vierem parar nessa thread
para conhecer a solução vão ficar frustados, pois só você conhece a solução.
Por favor, poste qual foi a solução, pois eu tinha um no final do codigo é indecifrável.

 

$_SESSION['msg_block'] = array(
        'tipo'=>"danger",
        'msg' =>"Você precisa logar no sistema!",
    );

esse e o código que eu uso para receber as mensagens de erro. então isso estava no final da pag_inicial.php (página que estava com problema)

 

Sobre as outras colocações que você colocou, vai ser difícil de explicar. sou meio enrolado e não quero tomar seu tempo.

 

Agradeço mais uma vez a colaboração e as dicas. Um abraço

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por Rafael_Ferreira
      Não consigo carregar a imagem do captcha do meu formulário. Foi testado com o xampp e easyphp. Também não carregou a imagem de outros captcha. 
       
       
    • Por luiz monteiro
      Olá, tudo bem?
       
      Estou melhorando meu conhecimento em php e mysql e, me deparei com o seguinte. A tabela da base de dados tem um campo do tipo varchar(8) o qual armazena números. Eu não posso alterar o tipo desse campo. O que preciso é fazer um select para retornar o números que contenham zeros a direita ou a esquerda.
      O que tentei até agora
       
      Ex1
      $busca = $conexao->prepare("select campo form tabela where (campo = :campo) ");
      $busca->bindParam('campo', $_REQUEST['campo_form']);
       
      Se a direita da string $_REQUEST['campo_form'] termina ou inicia com zero ou zeros, a busca retorna vazio.
      Inseri dados numéricos, da seguinte maneira para testar: 01234567;  12345670: 12345678: 12340000... entre outros nessa coluna. Todos os valores que não terminam ou não iniciam com zero ou zeros, o select funciona.
       
       
      Ex2
      $busca = $conexao->prepare("select campo form tabela where (campo = 0340000) ");
      Esse número está cadastrado, mas não retorna.
       
      Ex3
      $busca = $conexao->prepare("select campo form tabela where (campo = '02340001' ) ");
      Esse número está cadastrado, mas não retorna.
       
       
      Ex4
      $busca = $conexao->prepare("select campo form tabela where (campo like 2340000) ");
      Esse número está cadastrado, mas não retorna.
       
      Ex5
      $busca = $conexao->prepare("select campo form tabela where (campo like '12340000') ");
      Esse número está cadastrado, mas não retorna.
       
      Ex6
      $busca = $conexao->prepare("select campo form tabela where (campo like '"12340000"' ) ");
      Esse número está cadastrado, mas não retorna.
       
       
      Ex7
      $busca = $conexao->prepare("select campo form tabela where (campo like :campo) ");
      $busca->bindParam('campo', $_REQUEST['campo_form'])
      Não retorna dados.
       
      O  $_REQUEST['campo_form'] é envio via AJAX de um formulário. 
      Usei o gettype para verificar o post, e ele retorna string.
      Fiz uma busca com número 12345678 para verificar o que o select retorna, e também retrona como string.
       
      Esse tipo de varchar foi usado porque os números que serão gravados nesse campo,  terão zeros a direita ou na esquerda. Os tipos number do mysql não gravam zeros, então estou usando esse. O problema é a busca.
      Agradeço desde já.
       
       
    • Por daemon
      Boa tarde,
       
      Eu tenho uma rotina que faz uma leitura do arquivo .xml de vários sites.

      Eu consigo pegar o tópico e a descrição, e mostrar a imagem que esta na pagina do link.
      Para isso utilizo esta função:
      function getPreviewImage($url) { // Obter o conteúdo da página $html = file_get_contents($url); // Criar um novo objeto DOMDocument $doc = new DOMDocument(); @$doc->loadHTML($html); // Procurar pela tag meta og:image $tags = $doc->getElementsByTagName('meta'); foreach ($tags as $tag) { if ($tag->getAttribute('property') == 'og:image') { return $tag->getAttribute('content'); } } // Se não encontrar og:image, procurar pela primeira imagem na página $tags = $doc->getElementsByTagName('img'); if ($tags->length > 0) { return $tags->item(0)->getAttribute('src'); } // Se não encontrar nenhuma imagem, retornar null return null; } // Uso: $url = "https://example.com/article"; $imageUrl = getPreviewImage($url); if ($imageUrl) { echo "<img src='$imageUrl' alt='Preview'>"; } else { echo "Nenhuma imagem encontrada"; }  
      Mas estou com um problema, esta funcão funciona quando coloco em uma pagina de teste.php. Preciso mostrar em uma página inicial diversas fotos de todos os links. (No caso acima só funciona 1).
    • 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');     }  
×

Informação importante

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