Jump to content
Aureo Almeida

Formulário não envia parte de consultas

Recommended Posts

Possuo um formulário que está repassando parte dos dados que desejo enviar. Ele busca o resultado de três consultas e duas delas dão opções de seleção para  o usuário em input radio.

A primeira busca informações de produtos selecionados a partir de um parâmetro recebido via post. Este mesmo parâmetro também estabelece um critério para as outras duas consultas.

Todas elas funcionam adequadamente, sem problemas. A questão é que ao enviar o formulário somente os dois parâmetros que estão presentes em inputs hidden são enviados. Os dois inputs radio, que são preenchidos de acordo com determinados critérios, não.

Este é o código do formulario:

<form  action="carrinho.php" method="post">
         <?php

        //Recebe a variavel idproduto da página do produto
        $sub_id = $_POST['idproduto'];

       	$sql = "SELECT * FROM psd_produtos Where prd_id = '$sub_id'";
        $stmt = $conn->prepare($sql);
        $stmt->execute();
        $dados= $stmt->fetchAll(PDO::FETCH_OBJ);

   			foreach ($dados as $detProdutos): 
            $prdid = $detProdutos->prd_id;
            $nome= $detProdutos->prd_nome;
            $valor = $detProdutos->prd_valor;
    		$novovalor =  number_format($valor, 2, ',', '.');
            $quantidade = $detProdutos->prd_estoque;
            echo"
            <h2>PREÇO: R$ $novovalor</h2><br/>
            <input type='hidden' name='id' value='$prdid'>
            <input type='hidden' name='acao' value='add'>
            ";
    		endforeach;
 
		$sql1 = "SELECT * FROM  psd_cores WHERE prd_id = '$sub_id'AND crs_quantidade != '0'";
        $stmt1 = $conn->prepare($sql1);
        $stmt1->execute();
        $dados1= $stmt1->fetchAll(PDO::FETCH_OBJ);
   			  
			foreach ($dados1 as $prodCores):
             if($quantidade!= 0){
              echo"
                  <input type='radio' name='cor' id='cor' value='$prodCores->crs_cores' checked='checked'> $prodCores->crs_cores
                  <br>

                  ";}
   			endforeach;
		         
		 	$sql2 = "SELECT * FROM  psd_sabores WHERE prd_id = '$sub_id'AND sbr_quantidade != '0'";
         	$stmt2 = $conn->prepare($sql2);
         	$stmt2->execute();
         	$dados2= $stmt2->fetchAll(PDO::FETCH_OBJ);
              foreach ($dados2 as $prodSabores):
                 if($quantidade!= 0){
                 echo"
                    <input type='radio' name='sabor' id='sabor 'value='$prodSabores->sbr_sabor' checked='checked'> $prodSabores->sbr_sabor
                    <br>
               ";}
                 endforeach;
  	?>
    <input type='submit' class='imput-comprar' value='Comprar'>

</form>

O estranho é que se eu fizer um formulário com uma das  consultas isoladamente da demais, os parâmetros são enviados. Exemplo que funciona:

<form  action="carrinho.php" method="post">	 	
			$sql2 = "SELECT * FROM  psd_sabores WHERE prd_id = '$sub_id'AND sbr_quantidade != '0'";
         	$stmt2 = $conn->prepare($sql2);
         	$stmt2->execute();
         	$dados2= $stmt2->fetchAll(PDO::FETCH_OBJ);
              foreach ($dados2 as $prodSabores):
                 if($quantidade!= 0){
                 echo"
                    <input type='radio' name='sabor' id='sabor 'value='$prodSabores->sbr_sabor' checked='checked'> $prodSabores->sbr_sabor
                    <br>
               ";}
                 endforeach;?>
    <br><input type='submit' class='imput-comprar' value='Comprar'>

</form>

O que pode estar impedindo que os valores das duas consultas após a primeira não sejam enviadas em conjunto, somente isoladamente?

Share this post


Link to post
Share on other sites

Aureo Almeida

Fera, existe um erro básico no seu código.

Ao usar o LAÇO de FOREACH e exibir os RÁDIOS, você está colocando TODOS OS RÁDIOS com a opção CHECKED, mas aparentemente não existe nada de errado na página, pelo menos não neste local onde você monta o FORM.

 

Você pode postar o resultado testa página? Abrindo ela no seu navegador e exibindo o código fonte?

Gostaria de ver como está página fica depois de montada, talvez exista algum erro não visivel no arquivo PHP.

 

Poste o local que você recebe esses valores dentro de "carrinho.php".

 

Se a minha resposta for útil não esqueça de agradecer e votar positivo.

Espero ter ajudado de alguma forma.

 

Att
Felipe Guedes Coutinho

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 jranesio
      Estou com problemas com script PHP e cURL para:
      1 - logar no site
      2 - acessar formulario de pesquisa e passar os dados
      3 - receber a página de resposta html
      Itens 1 e 2 estão OK, obtenho a resposta (item 3).
      Alguém pode orientar onde estou errando? Segue script.
      Obrigado
       
       
      <?php
       
      $cookie = dirname(__FILE__).'/cookie.txt';
      $url1='http://clima.feis.unesp.br/login.php'; //página de login
      $url2='http://clima.feis.unesp.br/dados_diarios.php'; //formulario de pesquisa
      $url3='http://clima.feis.unesp.br/recebe_formulario.php'; //Resultado esperado
      $username = 'usuario=siteteste';
      $password = 'senha=testesite';
      $dadosform= [ 'dataini' => '01/01/2020',
      'datafim' => '01/03/2020',
      'estacao' => '1'
      ];
      $useragent='Mozilla/5.0 (Windows NT 6.2) AppleWebKit/536.6 (KHTML, like Gecko) Chrome/20.0.1090.0 Safari/536.6';
      $ch = curl_init($url2);
      curl_setopt_array($ch, [
                              CURLOPT_COOKIESESSION => 1,
                              CURLOPT_COOKIEJAR => $cookie,
                              CURLOPT_COOKIEFILE => $cookie,
                              CURLOPT_USERAGENT => $useragent,
                              CURLOPT_AUTOREFERER => 1,
                              CURLOPT_URL => $url2,
                              CURLOPT_POST => 1,
                              CURLOPT_RETURNTRANSFER => 1,
                              CURLOPT_FOLLOWLOCATION => 0,
                              CURLOPT_USERPWD => $username.":".$password,
                              CURLOPT_VERBOSE => 1 ,
                              CURLINFO_HEADER_OUT => 1,
                              CURLOPT_POSTFIELDS => $dadosform,
      ]);
      $resultado = curl_exec($ch);
      $errno = curl_errno($ch);
      echo "<br>Login: ". curl_strerror($errno).'<hr>';
      echo '<hr>';
      if($errno == 0) {
          print_r($resultado);
      }

      curl_close($ch);
      echo '<br>[FIM]';
       
    • By fideles
      Fala pessoal, tudo na paz? Como anda a quarentena ? Todos se cuidando....
       
      Seguinte, uma dúvida ou navalhada minha,
       
      Tenho um form simples, básico mesmo onde trampo, só para fazermos levantamento quando alguém chega.
       
      Nome da pessoa
      Um regime de contratação (CLT ou PJ) (input do tipo radio) (Nos value dos input radio tem CLT e PJ)
      Nome da empresa (campo oculto) (aqui funciona na boa)
       
      Preciso fazer com que se a pessoa clicar em PJ fazer ela preencher obrigatoriamente o campo "Nome da empresa" se ela for CLT não faz nada.
       
      Já tentei da seguinte forma e não da certo, talvez esteja errando por bobeira.
       
      if(empty($tipo_contratacao == "PJ")) { echo "<meta http-equiv='refresh' content='0; pesquisa_retorno_2.php'><script>alert('O campo nome da empresa não foi preenchido')</script>" ; return false; }  
      Alguém tem uma luz ?
       
      Obrigado.
    • By Alberto Nascimento
      Como faço para inserir data e horário no campo abaixo?
       
      <input name="horarioatual" id="horarioatual" style="width: 366px" type="text" />  
      Quando utilizava no PHP 5.3 funcionava com "echo", porém agora não esta mais quando estou utilizando o PHP 5.6
       
      <?php echo "$date"; ?>  
    • By Alberto Nascimento
      Estou utilizando agora PHP 7.2 em meu servidor e gostaria de saber onde consigo baixar ou se teriam algum exemplo de formulario PHP que inserisse dados em um banco de dados mysql.
       
      Utilizo o seguinte abaixo:
       
      index.php
      <?php session_start(); ?> <!DOCTYPE html> <html lang="pt-br"> <head> <meta charset="utf-8"> <title>CRUD - Cadastrar</title> </head> <body> <h1>Cadastrar Usuário</h1> <?php if(isset($_SESSION['msg'])){ echo $_SESSION['msg']; unset($_SESSION['msg']); } ?> <form method="POST" action="processa.php"> <label>Nome: </label> <input type="text" name="nome" placeholder="Digite o nome completo"><br><br> <label>E-mail: </label> <input type="email" name="email" placeholder="Digite o seu melhor e-mail"><br><br> <input type="submit" value="Cadastrar"> </form> </body> </html> processa.php
       
      <?php session_start(); include_once("conexao.php"); $nome = filter_input(INPUT_POST, 'nome', FILTER_SANITIZE_STRING); $email = filter_input(INPUT_POST, 'email', FILTER_SANITIZE_EMAIL); //echo "Nome: $nome <br>"; //echo "E-mail: $email <br>"; $result_usuario = "INSERT INTO usuarios (nome, email, created) VALUES ('$nome', '$email', NOW())"; $resultado_usuario = mysqli_query($conn, $result_usuario); if(mysqli_insert_id($conn)){ $_SESSION['msg'] = "<p style='color:green;'>Usuário cadastrado com sucesso</p>"; header("Location: index.php"); }else{ $_SESSION['msg'] = "<p style='color:red;'>Usuário não foi cadastrado com sucesso</p>"; header("Location: index.php"); } conexao.php
      <?php $servidor = ""; $usuario = ""; $senha = ""; $dbname = ""; //Criar a conexao $conn = mysqli_connect($servidor, $usuario, $senha, $dbname); Com isto, esta retornando as mensagens de erro abaixo:
      Linha: 8
       
      Linha: 12
       
      Linha: 14
       
      Obrigado desde já !!
    • By unset
      Olá... estou com um pequeno problema de lógica no meu sistema, e ainda não encontrei a solução se alguém puder ajudar
       
      Bom eu tenho um formulário onde contem dois campos, onde um serve para selecionar imagens e o outro para selecionar arquivos, da seguinte forma
       
      <form name="cadastrar" method="post" enctype="multipart/form-data"> <input type="file" multiple name="imagens[]" accept=".jpg, .jpeg, .png, .gif"/> <input type="file" multiple name="arquivos[]" accept=".pdf" /> </form> e no php eu verifico se eles estão vazios para chamar suas classes que fazem o resto, cadastrar no banco, enviar os arquivos etc...
       
      if (!empty($_FILES['imagens']['tmp_name'])): $imagens = new AdminPostagensImagens(); $imagens->enviarImagens($_FILES['imagens'], $id); endif; if (!empty($_FILES['arquivos']['tmp_name'])): $arquivos = new AdminPostagensArquivos(); $arquivos->enviarArquivos($_FILES['arquivos'], $id); echo 'saporra não pode carregar vazio'; endif; porém ao deixar o campo de enviar imagens vazio mesmo assim ele esta entrando na condição e chamando a classe, não sei onde está o erro, se alguém puder ajudar fico grato.
×

Important Information

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