Jump to content
getece

Combobox com Mysql

Recommended Posts

ini_set('display_errors', true);
error_reporting(E_ALL);

Boa tarde pessoal. Estou criando uma página PHP que puxa o combobox do mysql, e o restante das opções são digitadas pelo usuário. 

Então tenho duas páginas: index.php (com as formatações da pagina) e o conecta.php (com as informações da conexão do banco de dados.

Porém quando eu incluo a parte de verificação de campos vazios e a parte de gravar os dados no banco, todo o meu formulário HTML some, não da para escolher nem as opções do combobox mais.

Segue o código:

<html>
    <head>
        <meta http-equiv="content_Type" content="text/html; charset="UTF-8">
        <title>WebServiços - Agendamento</title>
    </head>
    <body>
        
        <form name="envia" action="conecta.php">
        <h1>WebServiços - Agendamento</h1>
        <th>Serviços:</th> 
        <select name="servicos">
        <?php
        $idServico = $_POST ["idServico"];
        $nomeServico = $_POST["nomeServico"];
        include_once ("conecta.php");
        $sql = "Select * from servico";
        $res = mysql_query($sql) or die ("Erro ao pesquisar os dados." . mysql_error());
        
        while ($registro = mysql_fetch_assoc($res)) {
            $idServico = $registro["idServico"];
            $nomeServico = $registro["nomeServico"];
            $nomePrestador = $registro ["nomePrestador"];
            echo "<option value='$idServico'>$nomeServico - $nomePrestador</option>";
        }
        ?>
        </select><br><br>
    <label for="nome">Nome do Cliente:   </label><input type="text" name="nomeCliente" size="40"><BR><BR>
    <label for="email">E-mail do Cliente: </label><input type="text" name="email" size="40"><BR><BR>
    <label for="telefone">Telefone do Cliente: </label><input type="text" name="telefone" size="38"><BR><BR>
    Dia: <select name="dia" style="width:60px;" >
        <option> 1 </option>
        <option> 2 </option>
        <option> 3 </option>
        <option> 4 </option>
        <option> 5 </option>
    </select>
   <br><br>Mês: <select name="mes" style="width:60px;">
        <option> 1 </option>
        <option> 2 </option>
        <option> 3 </option>
        <option> 4 </option>
        <option> 5 </option>
    </select>
   <br><br>Ano: <select name="ano" style="width:60px;">
        <option> 2017 </option>
        <option> 2018 </option>
        <option> 2019 </option>
        <option> 2020 </option>
    </select>
    <br><br>Hora: <select name="hora" style="width:60px;">
        <option> 12 </option>
        <option> 13 </option>
        <option> 14 </option>
        <option> 15 </option>
    </select>
        <br><br><input type="submit" value="Enviar"> 
                <input type="reset" value="limpar">
        </form>
        
      </body>
</html>

 

Código de conexão:

 


<?php
function validarCampos(&$msg, $nomeCliente, $email, $telefone) {
        $resultado = true;
        if (empty($nomeCliente)) {
            $msg = $msg . "Nome invalido.<BR>";
            $resultado = false;
        }
        if (empty($email)) {
            $msg = $msg . "E-mail  invalido. <BR>";
            $resultado = false;
        }
        if (empty($telefone)) {
            $msg = $msg . "telefone invalido.<BR>";
            $resultado = false;
        }

        return $resultado;
    }
        $nomeCliente = $_POST["nomeCliente"];
        $email = $_POST["email"];
        $telefone = $_POST["telefone"];
        
        $msg = "";
        if (validarCampos($msg, $nomeCliente, $email, $telefone)) {
        
 mysql_connect("localhost", "root", "1234") or die ("Não foi possível conectar ao banco de dados." . mysql_error());
    mysql_select_db("etec_servicos") or die ("Não foi possível encontrar o banco de dados." . mysql_error());
    
     $sql = "INSERT INTO agenda ( nomeCliente, email, telefone)
                VALUES ( '$nomeCliente' , '$email' , '$telefone') ";
        mysql_query($sql) or die("ERRO ao inserir dados do PARTICIPANTE. " . mysql_error());
    
        } else {
            echo "Erro. $msg";
        }
    
    ?>

Share this post


Link to post
Share on other sites

Getece,

Boa tarde!

 

Veja se atende suas necessidades:

<html>
    <head>
        <meta http-equiv="content_Type" content="text/html; charset="UTF-8">
        <title>WebServiços - Agendamento</title>
    </head>
    <body>
        
        <form name="envia" action="conecta.php" method="POST">
        <h1>WebServiços - Agendamento</h1>
        <th>Serviços:</th> 
        <select name="servicos">
        <?php
        $idServico = $_POST ["idServico"];
        $nomeServico = $_POST["nomeServico"];
        include_once ("conecta.php");
        $sql = "Select * from servico";
        $res = mysql_query($sql);
        
        while ($registro = mysql_fetch_assoc($res)) {
            $idServico = $registro["idServico"];
            $nomeServico = $registro["nomeServico"];
            $nomePrestador = $registro ["nomePrestador"];
            echo "<option value='$idServico'>$nomeServico - $nomePrestador</option>";
        }
        ?>
        </select><br><br>
    <label for="nome">Nome do Cliente:   </label><input type="text" name="nomeCliente" size="40"><BR><BR>
    <label for="email">E-mail do Cliente: </label><input type="text" name="email" size="40"><BR><BR>
    <label for="telefone">Telefone do Cliente: </label><input type="text" name="telefone" size="38"><BR><BR>
    Dia: <select name="dia" style="width:60px;" >
        <option> 1 </option>
        <option> 2 </option>
        <option> 3 </option>
        <option> 4 </option>
        <option> 5 </option>
    </select>
   <br><br>Mês: <select name="mes" style="width:60px;">
        <option> 1 </option>
        <option> 2 </option>
        <option> 3 </option>
        <option> 4 </option>
        <option> 5 </option>
    </select>
   <br><br>Ano: <select name="ano" style="width:60px;">
        <option> 2017 </option>
        <option> 2018 </option>
        <option> 2019 </option>
        <option> 2020 </option>
    </select>
    <br><br>Hora: <select name="hora" style="width:60px;">
        <option> 12 </option>
        <option> 13 </option>
        <option> 14 </option>
        <option> 15 </option>
    </select>
        <br><br><input type="submit" value="Enviar"> 
                <input type="reset" value="limpar">
        </form>
        
		
		<script src="https://code.jquery.com/jquery-1.10.2.js"></script>
		<script>
			$( 'form' ).submit(function(e){
				e.preventDefault();
				if( !$('input[name="nomeCliente"]').val() ){
					alert( 'Nome invalido' );
				}else if( !$('input[name="email"]').val() ){
					alert( 'E-mail  invalido' );
				}else if( !$('input[name="email"]').val() ){
					alert( 'telefone invalido' );
				}else{
					$(this).unbind('submit').submit();
				}
			});
		</script>
		
      </body>
</html>

 

Share this post


Link to post
Share on other sites

Boa tarde Vinapsy, a validação funciona porém o combobox só aparece as opções do banco se o conecta.php ficar da seguinte forma: 

<?php
 mysql_connect("localhost", "root", "1234") or die ("Não foi possível conectar ao banco de dados." . mysql_error());
    mysql_select_db("etec_servicos") or die ("Não foi possível encontrar o banco de dados." . mysql_error());
?>

 

E mesmo assim apresenta erro

Sem título.jpg

Share this post


Link to post
Share on other sites

Pra funcionar com mysqli o seu arquivo conecta.php terá que ficar desta forma:

<?php
function validarCampos($msg, $nomeCliente, $email, $telefone) {
        $resultado = true;
        if (empty($nomeCliente)) {
            $msg = $msg . "Nome invalido.<BR>";
            $resultado = false;
        }
        if (empty($email)) {
            $msg = $msg . "E-mail  invalido. <BR>";
            $resultado = false;
        }
        if (empty($telefone)) {
            $msg = $msg . "telefone invalido.<BR>";
            $resultado = false;
        }

        return $resultado;
    }
        $nomeCliente = $_POST["nomeCliente"];
        $email = $_POST["email"];
        $telefone = $_POST["telefone"];
        
        $msg = "";
        if (validarCampos($msg, $nomeCliente, $email, $telefone)) {
        
	$conexao = mysqli_connect("localhost", "root", "1234", "etec_servicos") or die ("Não foi possível conectar ao banco de dados." . mysqli_error($conexao));
    
     $sql = "INSERT INTO agenda ( nomeCliente, email, telefone)
                VALUES ( '$nomeCliente' , '$email' , '$telefone') ";
        mysqli_query($conexao, $sql) or die("ERRO ao inserir dados do PARTICIPANTE. " . mysqli_error($conexao));
    
        } else {
            echo "Erro. $msg";
        }
    
?>

 

E o seu index.php dessa forma:

<html>
    <head>
        <meta http-equiv="content_Type" content="text/html; charset=UTF-8">
        <title>WebServiços - Agendamento</title>
    </head>
    <body>
        
        <form name="envia" action="conecta.php" method="POST">
        <h1>WebServiços - Agendamento</h1>
        <th>Serviços:</th> 
        <select name="servicos">
        <?php
        $idServico = $_POST ["idServico"];
        $nomeServico = $_POST["nomeServico"];
        include_once ("conecta.php");
        $sql = "Select * from servico";
        $res = mysqli_query($conexao, $sql) or die (mysqli_error($conexao));
        
        while ($registro = mysql_fetch_assoc($res)) {
            $idServico = $registro["idServico"];
            $nomeServico = $registro["nomeServico"];
            $nomePrestador = $registro ["nomePrestador"];
            echo "<option value='$idServico'>$nomeServico - $nomePrestador</option>";
        }
        ?>
        </select><br><br>
    <label for="nome">Nome do Cliente:   </label><input type="text" name="nomeCliente" size="40"><BR><BR>
    <label for="email">E-mail do Cliente: </label><input type="text" name="email" size="40"><BR><BR>
    <label for="telefone">Telefone do Cliente: </label><input type="text" name="telefone" size="38"><BR><BR>
    Dia: <select name="dia" style="width:60px;" >
        <option> 1 </option>
        <option> 2 </option>
        <option> 3 </option>
        <option> 4 </option>
        <option> 5 </option>
    </select>
   <br><br>Mês: <select name="mes" style="width:60px;">
        <option> 1 </option>
        <option> 2 </option>
        <option> 3 </option>
        <option> 4 </option>
        <option> 5 </option>
    </select>
   <br><br>Ano: <select name="ano" style="width:60px;">
        <option> 2017 </option>
        <option> 2018 </option>
        <option> 2019 </option>
        <option> 2020 </option>
    </select>
    <br><br>Hora: <select name="hora" style="width:60px;">
        <option> 12 </option>
        <option> 13 </option>
        <option> 14 </option>
        <option> 15 </option>
    </select>
        <br><br><input type="submit" value="Enviar"> 
                <input type="reset" value="limpar">
        </form>
        
		
		<script src="https://code.jquery.com/jquery-1.10.2.js"></script>
		<script>
			$( 'form' ).submit(function(e){
				e.preventDefault();
				if( !$('input[name="nomeCliente"]').val() ){
					alert( 'Nome invalido' );
				}else if( !$('input[name="email"]').val() ){
					alert( 'E-mail  invalido' );
				}else if( !$('input[name="email"]').val() ){
					alert( 'telefone invalido' );
				}else{
					$(this).unbind('submit').submit();
				}
			});
		</script>
		
      </body>
</html>

Share this post


Link to post
Share on other sites

Pessoal, não sei se deveria abrir um novo tópico ou continuar nesse, se for preciso eu crio outro mas inicialmente vou postar aqui:

O meu problema mudou, consegui fazer aparecer todos os campos do meu código, porém quando eu clico em enviar, ele nao esta gravando no banco de dados.

 


<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="content_Type" content="text/html; charset="UTF-8">
        <title>WebServiços - Agendamento</title>
    </head>
    <body>
        
        <form name="envia" action="conecta.php">
        <h1>WebServiços - Agendamento</h1>
        <th>Serviços:</th> 
        <select name="servicos">
        <?php
        $idServico = $_POST ["idServico"];
        $nomeServico = $_POST["nomeServico"];
        $nomeCliente = $_POST ["nomeCliente"];
        $email = $_POST ["email"];
        $telefone = $_POST ["telefone"];
        
        include_once ("conecta.php");
        $sql = "Select * from servico";
        $sql2 = "INSERT INTO agenda ( nomeCliente, email, telefone)
                VALUES ( '$nomeCliente' , '$email' , '$telefone') ";
    
        $res = mysqli_query($conexao, $sql) or die ("Erro ao pesquisar os dados." . mysql_error());
        
        while ($registro = mysqli_fetch_assoc($res)) {
            $idServico = $registro["idServico"];
            $nomeServico = $registro["nomeServico"];
            $nomePrestador = $registro ["nomePrestador"];
            echo "<option value='$idServico'>$nomeServico - $nomePrestador</option>";
        }
        ?>
        </select><br><br>
    <label for="nome">Nome do Cliente:   </label><input type="text" name="nomeCliente" size="40"><BR><BR>
    <label for="email">E-mail do Cliente: </label><input type="text" name="email" size="40"><BR><BR>
    <label for="telefone">Telefone do Cliente: </label><input type="text" name="telefone" size="38"><BR><BR>
    Dia: <select name="dia" style="width:60px;" >
        <option> 1 </option>
        <option> 2 </option>
        <option> 3 </option>
        <option> 4 </option>
        <option> 5 </option>
        <option> 6 </option>
        <option> 7 </option>
        <option> 8 </option>
        <option> 9 </option>
        <option> 10 </option>
        <option> 11 </option>
        <option> 12 </option>
        <option> 13 </option>
        <option> 14 </option>
        <option> 15 </option>
        <option> 16 </option>
        <option> 17 </option>
        <option> 18 </option>
        <option> 19 </option>
        <option> 20 </option>
        <option> 21 </option>
        <option> 22 </option>
        <option> 23 </option>
        <option> 24 </option>
        <option> 25 </option>
        <option> 26 </option>
        <option> 27 </option>
        <option> 28 </option>
        <option> 29 </option>
        <option> 30 </option>
        <option> 31 </option>
    </select>
   <br><br>Mês: <select name="mes" style="width:60px;">
        <option> 1 </option>
        <option> 2 </option>
        <option> 3 </option>
        <option> 4 </option>
        <option> 5 </option>
        <option> 6 </option>
        <option> 7 </option>
        <option> 8 </option>
        <option> 9 </option>
        <option> 10 </option>
        <option> 11 </option>
        <option> 12 </option>
    </select>
   <br><br>Ano: <select name="ano" style="width:60px;">
        <option> 2017 </option>
        <option> 2018 </option>
        <option> 2019 </option>
        <option> 2020 </option>
    </select>
    <br><br>Hora: <select name="hora" style="width:60px;">
    <option> 7 </option>
        <option> 8 </option>
        <option> 9 </option>
        <option> 10 </option>
        <option> 11 </option>
        <option> 12 </option>
        <option> 13 </option>
        <option> 14 </option>
        <option> 15 </option>
        <option> 16 </option>
        <option> 17 </option>
    </select>
        <br><br><input type="submit" value="Enviar"> 
                <input type="reset" value="limpar">
        </form>
        <script src="https://code.jquery.com/jquery-1.10.2.js"></script>
        <script>
            $( 'form' ).submit(function(e){
                e.preventDefault();
                if( !$('input[name="nomeCliente"]').val() ){
                    alert( 'Nome invalido' );
                }else if( !$('input[name="email"]').val() ){
                    alert( 'E-mail  invalido' );
                }else if( !$('input[name="email"]').val() ){
                    alert( 'telefone invalido' );
                }else{
                    $(this).unbind('submit').submit();
                }
            });
        </script>
      </body>
</html>

 

conexao:


<?php
        
$conexao = mysqli_connect("localhost", "root","", "etec_servicos") or die ("Não foi possível conectar ao banco de dados." . mysqli_error());    
 
mysqli_query($conexao, "SET NAMES 'utf8'");
   mysqli_query($conexao, "SET character_set_connection=utf8");
   mysqli_query($conexao, "SET character_set_client=utf8");
   mysqli_query($conexao, "SET character_set_results=utf8");
    ?>
 

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By egalauber
      Preciso descobrir qual é o nome do arquivo com a extensão.
      Só sei o início do nome:
       
      pasta "anexos".
      nome_do_arquivo_DAQUI_PRA_FRENTE_NAO_SEI_O_RESTO_DO_NOME_NEM_A_EXTENSAO
       
      Com a função glob eu consigo achar o arquivo, mas o nome completo ainda não.
       
       
      $verifica = glob("anexos/nome_do_arquivo_*");
      if($verifica == true){
         // achei o arquivo e agora preciso pegar o nome completo e a extensão
      } else {
            echo "Arquivo não encontrado";
         }
    • By kelvinferraz
      Bom dia Pessoal,
       
      Estou com um problema que talvez muitos já devem ter passado, eu criei um FormRequest de um cadastro que fiz para validar os campos de anexo que vai para o BD. Incluindo a seguinte regra do name anexo_rg
        return [ 
                 'anexo_rg'           => 'mimes:jpeg,png,jpg,pdf|max:2048', 
              ];
       
      O campo não é required, porém ele fica pedindo para inserir um arquivo do tipo que foi criado na regra, ou seja, ele esta forçando um required no anexo, como consigo ignorar quando não possuir anexo?

      OBs: Eu criei um campo hidden para enviar um texto "NÃO POSSUI ANEXO". Antes de eu criar esse FormRequest ele conseguia deixar o anexo vazio, porém não tinha regras e a pessoa conseguia anexar qualquer tipo de arquivo.
       
    • By Vibraphera
      Oi gente eu recentemente comecei a aprender php e fui atras de desafios legais e me deparei com um que até hoje não consigo resolver.
      Preciso mostrar a maior e a menor palavra de uma frase ou texto. Eu tentei transformar em um array mas não sei se seria o adequado.
      Resumindo apenas me retorna corretamente a maior palavra mas a menor não me retorna nada. ALGUÉM ME DA UM HELP kk
      OBS: quando não tem ponto final parece que não retorna nada e quando tem ponto final ele retorna o 'ou' da frase mas não deveria retornar a letra 'é' ou a letra 'a'?
       
      <?php
      $texto = 'Como faço para saber qual é a menor e a maior de uma frase ou grandes textos';
      $arr = explode(" ", $texto);
      $maior="";
      $menor="";
      for ($i=0; $i <count($arr) ; $i++) { 
          $atual = $arr[$i];
          if (strlen($atual) > strlen($maior)) {
              $maior = $atual;
          } else if (strlen($atual) < strlen($maior)) {
              $menor = $atual;
          }
      }
      echo "<br>";
      echo $maior;
      echo "<br>";
      echo $menor;
    • By danteblatt
      Olá Srs,
      Não tenho muito conhecimento em PHP e estou com um formulário onde o usuário tem alguns campos para preencher e gravar no banco de dados SQL, sendo que um campo deste form será dinâmico onde o usuário poderá adicionar quantos campos forem necessários a partir de um botão "+".
      Nome do campo dinâmico: chavenf
      Segue abaixo o código do formulário:
      <form method="POST" action="../includes/mf-processa.php"> <div class="form-group"> <div class="form-row"> <div class="form-group col-md-4"> <input type="hidden" name="usuario[]" value="<?php echo $_SESSION['usuarioNome']; ?>" /> <select class="form-control" id="tipo" name="tipo[]"> <option selected>Tipo</option> <option>1</option> <option>2</option> </select> </div> <div class="form-group col-md-4"> <select class="form-control" id="prioridade" name="prioridade[]"> <option selected>Prioridade</option> <option>Alta</option> <option>Padrão</option> </select> </div> <div class="form-group col-md-4"> <input class="form-control" type="text" name="fornecedor[]" placeholder="Fornecedor" id="fornecedor"> </div> </div> <div style="display:none;" class="form-row" id="chavecte"> <div class="form-group col-md-12"> <label>Chave </label> <input class="form-control" type="text" name="chavecte[]"> </div> </div> <div class="form-row" id="row-nota"> <div class="form-group col-md-12"> <label>Chave da NF </label> <input class="form-control" type="text" name="chavenf[]" id="chavenf"> </div> </div> <div style="display:none;" class="form-row" id="add-field-nf"> <div class="form-group col-md-2"> <button type="button" class="btn btn-primary" id="add"> + </button> </div> </div> <div class="form-row"> <div class="form-group col-md-2"> <input type="submit" class="btn btn-primary" value="Cadastrar"> </div> </div> </div> </form> <script> $( "#add" ).click(function() { $( "#row-nota" ).append('<div class="form-group col-md-12"><input class="form-control" type="text" name="chavenf[]" id="chavenf"></div>'); }); </script> Abaixo o arquivo que conecta e insere no BD, "mf-processa.php"
      <?php session_start(); include_once("conexao.php"); $prioridade = filter_input(INPUT_POST, 'prioridade', FILTER_SANITIZE_STRING); $usuarioentrada = filter_input(INPUT_POST, 'usuario', FILTER_SANITIZE_STRING); $tipofrete = filter_input(INPUT_POST, 'tipofrete', FILTER_SANITIZE_STRING); $fornecedor = filter_input(INPUT_POST, 'fornecedor', FILTER_SANITIZE_STRING); $chavenf = preg_replace("/\s+/", "", filter_input(INPUT_POST, 'chavenf', FILTER_SANITIZE_STRING)); $chavecte = preg_replace("/\s+/", "", filter_input(INPUT_POST, 'chavecte', FILTER_SANITIZE_STRING)); $nNF = substr($chavenf, 25, 9); $timenow = date('d-m-Y'); $timenow .= ' '.date('H:i:s'); $qtnotas = count($chavenf)-1; for ($f = 0; $f <= $qtnotas; $f++) { $sql = "INSERT INTO base (data, usuarioentrada, prioridade, tipofrete, nf, fornecedor, chavenf, chavecte, acao, dataretorno, usuariofiscal) VALUES ( '.$timenow[$f].', '.$usuarioentrada[$f].', '.$prioridade[$f].', '.$tipofrete[$f].', '.$nNF[$f].', '.$fornecedor[$f].', '.$chavenf[$f].', '.$chavecte[$f].', '', '', '' )" or die ("<center>Erro: " . mysqli_error() . "</center>"); $insert = mysqli_query($conn, $sql); if(mysqli_insert_id($conn)){ $_SESSION['msgrec'] = "<p style='color:green;'>Nota cadastrada com sucesso!</p>"; header("Location: ../recebimento/recebimento.php"); }else{ $_SESSION['msgrec'] = "<p style='color:red;'>Nota não cadastrada com sucesso!</p>"; header("Location: ../recebimento/recebimento.php"); }  
       
      Veja o erro retornado na página.. Já tentei alterar o código e mesmo assim não consegui efetuar a inserção dos dados no BD.
       
      ( ! ) Warning: count(): Parameter must be an array or an object that implements Countable in D:\Wamp\www\RecebimentoAdm\includes\mf-processarecebimento.php on line 31 Call Stack # Time Memory Function Location 1 0.0001 411528 {main}( ) ...\mf-processarecebimento.php:0  
      ( ! ) Notice: Uninitialized string offset: 0 in D:\Wamp\www\RecebimentoAdm\includes\mf-processarecebimento.php on line 41 Call Stack # Time Memory Function Location 1 0.0001 411528 {main}( ) ...\mf-processarecebimento.php:0  
      ( ! ) Notice: Uninitialized string offset: 0 in D:\Wamp\www\RecebimentoAdm\includes\mf-processarecebimento.php on line 42 Call Stack # Time Memory Function Location 1 0.0001 411528 {main}( ) ...\mf-processarecebimento.php:0
    • By lordstarlight
      Olá, 
       
      Como posso bloquear todos ips, menos o meu para acesso ao meu site?
      preciso fazer isto para poder fazer manutenção.
       
      obrigado!
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.