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 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.