Ir para conteúdo

POWERED BY:

Arquivado

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

  • 0
Kerollin

Banco de dados e php

Pergunta

Gente, eu tive que criar um site para um trabalho de escola e criar um formulário cujo os dados vão para o banco de dados, eu fiz tudo certinho, o banco de dados ta conectado ao php do site, e as informações que eu coloco para preencher o formulário aparecem no bd normalmente, porém quando eu inicio a página, antes de inserir as informações, a página mostra que tem erro no código (porque os campos estão vazios), o ideal seria fazer uma condição enquanto os campos estiverem vazios né? Mas não faço a minima ideia de como, já tentei várias formas que vi por aqui..

Na página aparece assim: Notice: Undefined index: Nome in C:\xampp\htdocs\Site\PagContato.php on line 7 (junto com as outras linhas de dado, como email, ddd, telefone e etc)
                                               Erro:SQLSTATE[23000]: Integrity constraint violation: 1048 Column 'Nome' cannot be null

 

Meu código ta assim

 

<?php
    $nome_bd ='teste';
    $usuario_bd = 'root';
    $senha_bd = '';
    $host_bd = 'localhost';

 

    $Nome = $_POST ['Nome'];
    $Email = $_POST ['Email'];
    $DDD = $_POST ['DDD'];
    $Telefone = $_POST ['Telefone'];
    $Assunto = $_POST ['Assunto'];
    $Mensagem = $_POST ['Mensagem'];
    include 'Template.php';
    include 'Conexao.php';
    $conexao = new Conexao();
    $template = new Template();
    

        try{
            $conexao = new PDO("mysql:host=$host_bd;dbname=$nome_bd", $usuario_bd,$senha_bd);
            $conexao->setAttribute (PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
            $stmt = $conexao -> prepare(
                        'INSERT INTO contato(Nome, Email, DDD, Telefone, Assunto, Mensagem) VALUES (:Nome, :Email, :DDD, :Telefone, :Assunto, :Mensagem)'
                        );
            $stmt->bindValue(":Nome", $Nome);
            $stmt->bindValue(":Email", $Email);
            $stmt->bindValue(":DDD", $DDD);
            $stmt->bindValue(":Telefone", $Telefone);
            $stmt->bindValue(":Assunto", $Assunto);
            $stmt->bindValue(":Mensagem", $Mensagem);
            $stmt->execute();
            echo $stmt->rowCount()."linha(s) inseridas";
        }catch(PDOException $e){
            echo "Erro:".$e->getMessage();
        }
    
        

    echo $template->topo();
?>

 

<form method = "post" action = "PagContato.php" id = "contato" form id = "teste">
        
        <fieldset>
            <legend> Contato </legend>
                <label for = "Nome">
                    Nome: (<span> * </span>)
                </label>
                
                <input data-progression type = "text"  name = "Nome" id = "Nome" value = "" placeholder = "" />
                <label for = "Email">
                    E-mail: (<span> * </span>)
                </label>
                <input data-progression type = "text" name = "Email" id = "Email" value = "" placeholder = "" />
                <article id = "ddd-telefone">
                    <p class = "um">
                        <label for = "DDD">
                            DDD:
                        </label>
                        <input data-progression type = "text" name = "DDD" id = "DDD" value = "" placeholder = "" />
                    </p>
                    <p class = "dois">
                        <label for = "Telefone">
                            Telefone:
                        </label>
                        <input data-progression type = "text" name = "Telefone" id = "Telefone" value = "" placeholder = ""/>
                </article>
                    <label for = "Assunto">
                        Assunto: (<span> * </span>)
                    </label>
                <select name = "Assunto" id = "Assunto">
                    <option value = "">
                        Escolha um assunto
                    </option>
                    <option value = "Descrição do produto">
                        Descrição do produto
                    </option>
                    <option value = "Como funciona o produto">
                        Como funciona o produto
                    </option>
                    <option value = "Manutenção">
                        Manutenção
                    </option>
                    <option value = "Outros">
                        Outros
                    </option>
                </select>
                    <label for = "Mensagem">
                        Mensagem: (<span> * </span>)
                    </label>
                    <textarea name = "Mensagem" id = "Mensagem" cols = "" rows = ""></textarea>
                    <input data-progression type = "submit" name = "enviar" id = "enviar" value = "Enviar"/>
        </fieldset>

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

2 respostas a esta questão

Recommended Posts

O alerta é porque o está vazio ou o valor é nulo no índice da super-global $_POST

 

Então levantarei uma dúvida:

Esse é um único arquivo, ao qual você insere os dados e o mesmo registra?

Porque se form está requisitando a validação em outro arquivo PagContato.php

action = "PagContato.php" 

No caso é nesse arquivo que as informações de registro deve ficar.

 

Como você disse que era um trabalho escolar seu professor deveria ter lhe falado sobre verificar valores antes de validar-los.

Spoiler

if (!isset($_POST['Nome'])) {
    echo "Nome não foi definido";
} else if (!isset($_POST['Email'])) {
    echo "Email não foi definido";
} else if (isset($_POST['DDD'])) {
    echo "DDD não foi definido";
} else if (!isset($_POST['Telefone'])) {
    echo "Telefone não foi definido";
} else if (!isset($_POST['Assunto'])) {
    echo "Assunto não foi definido";
} else if (!isset($_POST['Mensagem'])) {
    echo "Mensagem não foi definida";
} else {
   // Execução do código dentro desse laço.....
}

 

 

Lógico isso que coloquei acima não é uma validação é apenas uma checagem se os valores realmente existem.

 

Detalhe, não use $_POST ['VALOR'] use assim: $_POST['VALOR'], sem dar espaço entre a índice da array e seu valor.

 

E se for fazer a validação do post no mesmo arquivo que contém o formulário use lógica de exitência como mostrei acima:

Spoiler

<?php
if (isset($_POST)) {
    echo "Recebido POST: {$_POST['inputTXT']}";
}
?>

<form method="POST">
    <input type="text" maxlength="30" name="inputTXT" />
    <button type="submit"> Enviar </button>
</form>

 

 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

@Omar~, É um único arquivo onde eu requisito e insiro os dados, tinha feito a condição assim:

if(isset($_POST['Enviar'])){
        if(isset($_POST["submit"]) || empty($_POST['Nome']) || empty($_POST['Email']) || empty($_POST['DDD']) || empty($_POST['Telefone']) || empty($_POST['Assunto']) || empty($_POST['Mensagem'])){
            $error = true;
        }
        else{
            $Nome = $_POST['Nome'];
            $Email = $_POST['Email'];
            $DDD = $_POST['DDD'];
            $Telefone = $_POST['Telefone'];
            $Assunto = $_POST['Assunto'];
            $Mensagem = $_POST['Mensagem'];
        }
    }

Mas aí aparece o erro "Erro:SQLSTATE[23000]: Integrity constraint violation: 1048 Column 'Nome' cannot be null"

 

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 daemon
      Tenho um site com mais de 50.000 notícias, queria gerar um sitemap.xml.

      Existe algo gratuito ? O site foi desenvolvido do zero.
    • Por daemon
      Tenho um site com mais de 50.000 notícias, queria gerar um sitemap.xml.

      Existe algo gratuito ? O site foi desenvolvido do zero.
    • 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).
×

Informação importante

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