Ir ao conteúdo

Posts recomendados

Postado
        <?php

        if($_POST){
 
 
            // pega os dados do formuário
            $socceruser = isset($_POST['socceruser']) ? $_POST['socceruser'] : null;
            $soccersenha = isset($_POST['soccersenha']) ? $_POST['soccersenha'] : null;
             
            // validação (bem simples, só pra evitar dados vazios)
            if (empty($socceruser) || empty($soccersenha))
            {
                echo "<p class='redcolor'>Volte e preencha todos os campos.</p>";
               
            }

            $PDO = db_connect();
            $sql = "INSERT INTO logar(socceruser, soccersenha) VALUES(:socceruser, :soccersenha)";
            
            $stmt = $PDO->prepare($sql);
            $stmt->bindParam(':socceruser', $socceruser);
            $stmt->bindParam(':soccersenha', $soccersenha);
            
             
            if ($stmt->execute())
            {
                echo "<p class='alert alert-success'>Cadastro efetuado com sucesso! Redirecionando...</p>";
                
            }
            
            else
            {
                echo "<p class='redcolor'>Erro ao cadastrar!</p>";

            }

header('refresh: 3;novousuario.php');
}

            ?>

Ola boa tarde, alguem pode me ajudar, quando a pessoa se cadastra no meu site, não diz se tem o usuario cadastrado com esse nome, então ele duplica os valores no banco de dados, sou leigo em php ainda, um amigo meu q fez esse codigo, alguem pfv me ajuda

  • Moderador
Postado

@LuanCSM Olá.

 

Isso é porque você não testa antes se já existe.

Faça uma consulta na tabela e coloca uma condição IF-ELSE onde se existir, apresenta mensagem que já existe senão faz a inserção do dado.

 

Basicamente é isso que você precisa fazer. :thumbsup:

 

  • Moderador
Postado

@LuanCSM O que parte exatamente você não entendeu?

 

O seu problema é que quando cadastra algo na tabela ele é repetido. Ou seja, você precisa fazer uma verificação se já existe um registro com o valor desejado.

 

Seu amigo fez esse código nas "coxas".

 

O código ficaria mais ou menos assim:

     if($_POST){
            // pega os dados do formuário
            $socceruser = isset($_POST['socceruser']) ? $_POST['socceruser'] : null;
            $soccersenha = isset($_POST['soccersenha']) ? $_POST['soccersenha'] : null;
             
            // validação (bem simples, só pra evitar dados vazios)
            if (empty($socceruser) || empty($soccersenha)):
                echo "<p class='redcolor'>Volte e preencha todos os campos.</p>";     
            endif;


//cria a conexão com o banco de dados
$PDO = db_connect();

//consulta na tabela o nome de usuário
$verifica = $PDO->prepare("SELECT socceruser FROM logar WHERE socceruser= :socceruser");
$stmt->bindParam(":socceruser",$socceruser);

//Executa o statement 
$stmt->execute();
//Obtém o número de linhas registradas
$numLinhas = $stmt->rowCount();

//Testa se o número de linhas for maior que zero. Se for, significa que já existe um nome de usuário em uso
if($numLinhas > 0):
       echo "<p class='redcolor'>Usuário já existe, escolha outro.</p>";

else:

            $sql = "INSERT INTO logar(socceruser, soccersenha) VALUES(:socceruser, :soccersenha)";
            
            $stmt = $PDO->prepare($sql);
            $stmt->bindParam(':socceruser', $socceruser);
            $stmt->bindParam(':soccersenha', $soccersenha);
            
             
            if ($stmt->execute()):
                echo "<p class='alert alert-success'>Cadastro efetuado com sucesso! Redirecionando...</p>";
            else:   
                echo "<p class='redcolor'>Erro ao cadastrar!</p>";
            endif;

            header('refresh: 3;novousuario.php');


endif;
}

Recomendo que não copie o código, estude e aprenda. Não há garantias de que vai funcionar.

  • Curtir 1
Postado
7 horas atrás, DiF disse:

@LuanCSM O que parte exatamente você não entendeu?

 

O seu problema é que quando cadastra algo na tabela ele é repetido. Ou seja, você precisa fazer uma verificação se já existe um registro com o valor desejado.

 

Seu amigo fez esse código nas "coxas".

 

O código ficaria mais ou menos assim:


     if($_POST){
            // pega os dados do formuário
            $socceruser = isset($_POST['socceruser']) ? $_POST['socceruser'] : null;
            $soccersenha = isset($_POST['soccersenha']) ? $_POST['soccersenha'] : null;
             
            // validação (bem simples, só pra evitar dados vazios)
            if (empty($socceruser) || empty($soccersenha)):
                echo "<p class='redcolor'>Volte e preencha todos os campos.</p>";     
            endif;


//cria a conexão com o banco de dados
$PDO = db_connect();

//consulta na tabela o nome de usuário
$verifica = $PDO->prepare("SELECT socceruser FROM logar WHERE socceruser= :socceruser");
$stmt->bindParam(":socceruser",$socceruser);

//Executa o statement 
$stmt->execute();
//Obtém o número de linhas registradas
$numLinhas = $stmt->rowCount();

//Testa se o número de linhas for maior que zero. Se for, significa que já existe um nome de usuário em uso
if($numLinhas > 0):
       echo "<p class='redcolor'>Usuário já existe, escolha outro.</p>";

else:

            $sql = "INSERT INTO logar(socceruser, soccersenha) VALUES(:socceruser, :soccersenha)";
            
            $stmt = $PDO->prepare($sql);
            $stmt->bindParam(':socceruser', $socceruser);
            $stmt->bindParam(':soccersenha', $soccersenha);
            
             
            if ($stmt->execute()):
                echo "<p class='alert alert-success'>Cadastro efetuado com sucesso! Redirecionando...</p>";
            else:   
                echo "<p class='redcolor'>Erro ao cadastrar!</p>";
            endif;

            header('refresh: 3;novousuario.php');


endif;
}

Recomendo que não copie o código, estude e aprenda. Não há garantias de que vai funcionar.

Ok obrigado pela informação, n irei copiar, mais ja deu uma grande noção para mim!valeu pela atenção 

Crie uma conta ou entre para comentar

Você precisa ser um usuário para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar agora

Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas comunidades sobre tecnologia do Brasil. Leia mais

Direitos autorais

Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

×
×
  • Criar novo...

LANÇAMENTO!

eletronica2025-popup.jpg


CLIQUE AQUI E BAIXE AGORA MESMO!