Ir para conteúdo

POWERED BY:

Arquivado

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

Ak_Ray

Exibir dados registrados no Banco de dados

Recommended Posts

  Olá pessoal, estou com um problema relativamente simples! mas sou novo em banco de dados e php então não consegui resolver. Estou construindo um sistema de registro e login há um certo tempo, meu professor ainda não ensinou e não ensina muito bem então decidi aprender sozinho por tutoriais na internet ._. então achei um tutorial legal, segui todos os passos e está tudo funcionando! porém, agora quero exibir os dados registrados, porém não sei como fazer isso, quero exibir em específico o nome do usuário. Lembrando que sou novo nesse assunto então desconsiderem minha maneira de programar kkk

 

================================================================================================================================

Código php:

<?php

class Usuario
{
    private $pdo;
    public $msgErro = "";
    public function conectar($nome, $host, $usuario, $senha)
    {
        global $pdo;
        global $msgErro;
        try {
        $pdo = new PDO("mysql:dbname=".$nome.";host=".$host,$usuario,$senha);    
        } catch (PDOException $e) {
            $msgErro = $e->getMessage(); 
        }
    return $conectar;    
    }

    public function cadastrar($nome, $telefone, $email, $senha)
    {
        global $pdo;
        //verificar se já existe email cadastrado 
        $sql = $pdo->prepare("SELECT id_usuario from usuarios where email = :e");
        $sql->bindValue(":e",$email);
        $sql->execute();
        if($sql->rowCount() > 0)
        {
            return false; // ja esta cadastrado
        }
        else 
        {
             //caso não, cadastrar 
             $sql = $pdo->prepare("INSERT INTO usuarios (nome,telefone,email,senha) VALUES (:n, :t, :e, :s)");
             $sql->bindValue(":n",$nome);
             $sql->bindValue(":t",$telefone);
             $sql->bindValue(":e",$email);
             $sql->bindValue(":s",md5($senha));
             $sql->execute();
             return true; 
        }     
        
    }
    public function logar($email, $senha)
    {
        global $pdo;
        //verificar se  o email e senha estao cadastrados, se sim  
        $sql = $pdo->prepare("SELECT id_usuario from usuarios where email = :e and senha = :s");
        $sql->bindValue(":e",$email);
        $sql->bindValue(":s",md5($senha));
        $sql->execute();
        if($sql->rowCount() > 0)
        {
           //entrar no sistema (sessao)
           $dado = $sql->fetch();
           session_start();
           $_SESSION['id_usuario'] = $dado['id_usuario'];
           return true; //logado com sucesso 
        }
        else
        {
           return false;//nao foi possível logar
        }
        //entrar no sistema (sessao)
    }
}

?>

 

================================================================================================================================

Código html:

<!-- verificação se está logado -->
<?php 
session_start(); 
if(!isset($_SESSION['id_usuario']))

header("location: index.php"); 
exit; 
}
else{    
    include ('CLASSES/usuarios.php');
    require_once 'CLASSES/usuarios.php';
    $consulta = "SELECT nome from usuarios"; //aqui estava tentando puxar os dados por um tutorial aleaório


}
?> 

<html lang="pt-br">
<head>
<meta charset="utf-8">
<link rel="stylesheet" href="CSS/estilouser.css" type="text/css" media="screen">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">
<link href="https://fonts.googleapis.com/icon?family=Material+Icons" rel="stylesheet"> 
<title> Ak_Ray Projects </title>
</head> <body bgcolor="#B3D1F7">


<div class="navbar">
<a href="#home">Meu</a>
<a href="#news">Projetos</a>
<a href="#newss">Novidades</a>
<a href="sair.php" style="position: relative;left:1020px;">Sair</a>
<!--<a href="sair.php">Sair</a>-->
</div>

<div class="branco"> 
<h2>
  <center>
   <font color="#20A1C6">
    Criação e Desenvolvimento de Jogos<br>Ak_Ray
   </font>
  </center>
 </h2>

<div class="titlee">
<strong>The Amazing word of Bimo</strong>
<div class="contt">
<center><img src="IMG/FOTOJOGO.png" width="150" style="border-radius: 20px;"></center>
<a href=\"bimo.netlify.com\"><img class="animacao" src="IMG/button.png" width="40"></a>
</div>
</div><br>
The Amazing Word of Bimo foi um Jogo criado em 2019, inspirado na franquia de jogos de <strong>Super Mario World.</strong>
O jogo está em versão de desenvolvimento e está sendo produzido e alterado
constantemente. 

</div>

<?php  echo con;  ?> // exibindo só de teste


</body></html>

 

================================================================================================================================

Obs caso precisem: 

nome do banco de dados:  projeto_login

host: localhost

usuario: root

senha: ""

tabela criada: usuarios

tutoriais assistidos: 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Primeiramente cuidado para não aprender da forma errada!

13 horas atrás, Ak_Ray disse:

então decidi aprender sozinho por tutoriais na internet

 

Bom o que irá fazer para trazer os resultados é dar um select na tabela que deseja, assim como está fazendo. Então é só executar um fetchAll nos dados.

Exemplo:

$sql = $pdo->prepare("SELECT * FROM usuarios");
$sql->execute();
$dados = $sql->fetchAll(PDO::FETCH_ASSOC);
if($sql->rowCount()) {
    echo "<pre>";
    var_dump($dados);
    echo "</pre>";
}

Nesse caso é todos os dados da tabela "usuarios", mas você pode buscar por ídices expecíficos também através de bind ou statements.

 

 

Eu preparei um tópico aqui no iMasters para ajudar quem se adentra no PDO, pode ser útil para você nesse começo.

https://forum.imasters.com.br/topic/565800-crud-introdução-a-pdo/

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
4 horas atrás, Omar~ disse:

Primeiramente cuidado para não aprender da forma errada!

 

Bom o que irá fazer para trazer os resultados é dar um select na tabela que deseja, assim como está fazendo. Então é só executar um fetchAll nos dados.

Exemplo:


$sql = $pdo->prepare("SELECT * FROM usuarios");
$sql->execute();
$dados = $sql->fetchAll(PDO::FETCH_ASSOC);
if($sql->rowCount()) {
    echo "<pre>";
    var_dump($dados);
    echo "</pre>";
}

Nesse caso é todos os dados da tabela "usuarios", mas você pode buscar por ídices expecíficos também através de bind ou statements.

 

 

Eu preparei um tópico aqui no iMasters para ajudar quem se adentra no PDO, pode ser útil para você nesse começo.

https://forum.imasters.com.br/topic/565800-crud-introdução-a-pdo/

 

 

Opa obrigado amigo por esta ajuda! Acabei de ler o seu tópico sobre PDO, agora tenho um pouco mais de noção do que estou fazendo :D. Não entendi muito bem esta passagem do seu tópico: "

$update->execute(['username' => 'Chapolin', 'userlogin' => 'Chiquinha', 'userid' => 1]);

Creio que talvez seja por isso que ainda esteja com problemas, adicionei a linha de código que você me passou e me apareceu isso: 

 

Notice: Undefined variable: pdo in C:\xampp\htdocs\Sistema de Cadastro beta0.1\AreaPrivada.php on line 53

Fatal error: Uncaught Error: Call to a member function prepare() on null in C:\xampp\htdocs\Sistema de Cadastro beta0.1\AreaPrivada.php:53 Stack trace: #0 {main} thrown in C:\xampp\htdocs\Sistema de Cadastro beta0.1\AreaPrivada.php on line 53

 

Claro tentei entender várias vezes, fazer de várias formas e não obtive sucesso, se puder me ajudar novamente serei muito grato :D 

Compartilhar este post


Link para o post
Compartilhar em outros sites
19 horas atrás, Ak_Ray disse:

Notice: Undefined variable: pdo in C:\xampp\htdocs\Sistema de Cadastro beta0.1\AreaPrivada.php on line 53

Isso é porque a variável pdo não existe!

Logo ela deve ser criada para instancia da classe PDO. Se ela não foi criada ou ouve erro ao criar a instancia irá gerar esse erro.

 

 

19 horas atrás, Ak_Ray disse:

Não entendi muito bem esta passagem do seu tópico: "


$update->execute(['username' => 'Chapolin', 'userlogin' => 'Chiquinha', 'userid' => 1]);

Aqui é subjetivo.... Enfim basicamente é passar um array com os índices esses serão os mesmos do statement e os valores de cada índice é os dados a manipular.

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • 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
    • Por violin101
      Caros amigos, saudações.
       
      Humildemente peço desculpa por postar uma dúvida que tenho.

      Preciso salvar no MySql, os seguinte Registro:

      1 - Principal
      ====> minha dúvida começa aqui
      ==========> como faço para o Sistema Contar Automaticamente o que estiver despois do 1.____?
      1.01 - Matriz
      1.01.0001 - Estoque
      1.01.0002 - Oficina
      etc

      2 - Secundário
      2.01 - Loja_1
      2.01.0001 - Caixa
      2.01.0002 - Recepção
      etc
       
      Resumindo seria como se fosse um Cadastro de PLANO de CONTAS CONTÁBEIL.

      Grato,


      Cesar









       
×

Informação importante

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