Jump to content
peterstefan

validar campos com php

Recommended Posts

Olá, tenho 4 campos em um formulario, porem eles não são obrigatórios, queria ver qual tecnica para fazer que o cliente preencha pelo menos um dos campos. caso ele tente enviar vazio mostrar uma mensagem para ele avisando que tem que preencher pelo menos um dos 4 campos... 

 

Obrigado!!

Share this post


Link to post
Share on other sites

Bom dia, ShadowDLL! Obrigado por responder.. Deixa eu te falar, nesses links que você me passou a possibilidade tipo, tenho 4 campos, mais 3 deles não tenho a informação mais em um eu tenho, ai eu preencho somente o campo que eu tenho a informação, mais caso eu não preencha nenhum deles e tendo cadastrar, o sistema me avisar que tenho que preencher pelo menos um dos 4 campos...

não quero deixar os campos obrigatório e sim ao menos 1 dos 4 caso nenhum dos campos tenha sido informado...

Share this post


Link to post
Share on other sites

peterstefan

Primeiro você precisa definir o TIME de sua validação.

 

Em JavaScript você consegui validar em TEMPO DE EXECUÇÃO, ou sejá, a pessoa preenche e você já valida.

Ou se a sua validação será feita após o envio do formulário com o uso do PHP.

 

Exemplo JavaScript:

ARQUIVO index.php

<script type="text/javascript">
function checkPreenchimento(){    
    if(document.getElementById("IdDoSeuTextboxCampo1").value.length > 0) {
        document.getElementById("IdDoSeuTextboxCampo1").required = true;
        document.getElementById("IdDoSeuTextboxCampo2").required = false;
        document.getElementById("IdDoSeuTextboxCampo3").required = false;
        document.getElementById("IdDoSeuTextboxCampo4").required = false;
    } else if (document.getElementById("IdDoSeuTextboxCampo2").value.length > 0) {
        document.getElementById("IdDoSeuTextboxCampo1").required = false;
        document.getElementById("IdDoSeuTextboxCampo2").required = true;
        document.getElementById("IdDoSeuTextboxCampo3").required = false;
        document.getElementById("IdDoSeuTextboxCampo4").required = false;
    } else if (document.getElementById("IdDoSeuTextboxCampo3").value.length > 0) {
        document.getElementById("IdDoSeuTextboxCampo1").required = false;
        document.getElementById("IdDoSeuTextboxCampo2").required = false;
        document.getElementById("IdDoSeuTextboxCampo3").required = true;
        document.getElementById("IdDoSeuTextboxCampo4").required = false;
    } else if (document.getElementById("IdDoSeuTextboxCampo4").value.length > 0) {
        document.getElementById("IdDoSeuTextboxCampo1").required = false;
        document.getElementById("IdDoSeuTextboxCampo2").required = false;
        document.getElementById("IdDoSeuTextboxCampo3").required = false;
        document.getElementById("IdDoSeuTextboxCampo4").required = true;
    } else {
        document.getElementById("IdDoSeuTextboxCampo1").required = true;
        document.getElementById("IdDoSeuTextboxCampo2").required = true;
        document.getElementById("IdDoSeuTextboxCampo3").required = true;
        document.getElementById("IdDoSeuTextboxCampo4").required = true;
    }
}
</script>

 

* E você chama a função ao apertar qualquer tecla no INPUT de todos os seus INPUT <br>

<form name="formSend" method="post" action="incluir.php" >
<input type="text" name="IdDoSeuTextboxCampo1" id="IdDoSeuTextboxCampo1" onKeyUp="checkPreenchimento()" autofocus required />
<input type="text" name="IdDoSeuTextboxCampo2" id="IdDoSeuTextboxCampo2" onKeyUp="checkPreenchimento()" required />
<input type="text" name="IdDoSeuTextboxCampo3" id="IdDoSeuTextboxCampo3" onKeyUp="checkPreenchimento()" required />
<input type="text" name="IdDoSeuTextboxCampo4" id="IdDoSeuTextboxCampo4" onKeyUp="checkPreenchimento()" required />
<input type="image" src="qualquer.png" align="center" /></td>
</form>

...

Copiar até o </form> para o exemplo em JavaScript e colocar dentro de index.php

 

Exemplo em PHP:

ARQUIVO index.php

<?php session_start();
if (!empty($_SESSION['msg_alerta'])) {
    echo "<font color='#FF3300'>Alerta: </font>".$_SESSION['msg_alerta'];
    $_SESSION['msg_alerta'] = "";
} ?>
<form name="formSend" method="post" action="incluir.php" >
<input type="text" name="IdDoSeuTextboxCampo1" id="IdDoSeuTextboxCampo1" autofocus  />
<input type="text" name="IdDoSeuTextboxCampo2" id="IdDoSeuTextboxCampo2" />
<input type="text" name="IdDoSeuTextboxCampo3" id="IdDoSeuTextboxCampo3" />
<input type="text" name="IdDoSeuTextboxCampo4" id="IdDoSeuTextboxCampo4" />
<input type="image" src="images/add_item_banco_16.png" align="center" /></td>
</form>

 

ARQUIVO incluir.php

<?php
if (empty($_POST['IdDoSeuTextboxCampo1']) and empty($_POST['IdDoSeuTextboxCampo2']) and empty($_POST['IdDoSeuTextboxCampo3']) and empty($_POST['IdDoSeuTextboxCampo4'])) {
    session_start();
    $_SESSION['msg_alerta'] = "Você deve preencher ao menos um campo!";
    header("Location: index.php");
    exit();
};

echo "Um dos valores foi preenchido, então você pode continuar o seu processo para incluir na BASE DE DADOS <br>";
?>

 

Espero ter ajudado.

 

Att.

Felipe Coutinho

Share this post


Link to post
Share on other sites

Segue exemplo:

 

CÓDIGO

<?php

$_POST = array (
	# NÂO SERÂO VERIFICADOS
	'name' => 'Olavo Souza',
	'phone' => '+99 (99) 9 9999-9999',
	# SERÂO VERIFICADOS
	'email_1' => '',
	'email_2' => 'email@email.com',
	'email_3' => '',
	'email_4' => 'email@email.com'
);

# CAMPOS INFORMADOS
$informed_fields = array ();

# QUAIS INDICES SERÃO REVISADO?
$verify = array (
	'email_1', 'email_2', 'email_3', 'email_4'
);

# VERIFICAÇÂO
foreach ( $_POST as $indice => $value ) {
	# PESQUISA SE O INDICE DO POST
	# IRÀ SER VERIFICADO
	if ( in_array ( $indice , $verify ) ) {
		# ANALISA SE O CAMPO NÃO ESTÁ
		# VÁZIO
		if ( ! empty ( $value ) ) {
			# ADICIONA NO ARRAY
			$informed_fields [] = $indice;
		}
	}
}

if ( count ( $informed_fields ) > 0 ) {
	var_dump ( $informed_fields );
} else {
	echo "Error :(";
}

 

Share this post


Link to post
Share on other sites

peterstefan

Segue um exemplo caso você queira fazer com JavaScript apenas:

A inicio TODOS os 4 campos são obrigatórios, assim que você digita QUALQUER VALOR em um dos 4 campos os outros deixam de ser obrigatórios.

<html xmlns='http://www.w3.org/1999/xhtml'>
<head>
<meta name='keywords' content='' />
<meta name='description' content='' />
<meta http-equiv='content-type' content='text/html; charset=utf-8' />
<link rel='stylesheet' type='text/css' href='css/style.css' />
<title>Check Campos</title>
<script type='text/javascript'>
function checkPreenchimento() {
    document.getElementById('IdDoSeuTextboxCampo1').required = true;
    document.getElementById('IdDoSeuTextboxCampo2').required = true;
    document.getElementById('IdDoSeuTextboxCampo3').required = true;
    document.getElementById('IdDoSeuTextboxCampo4').required = true;
    if(document.getElementById('IdDoSeuTextboxCampo1').value.length > 0) {
        document.getElementById('IdDoSeuTextboxCampo1').required = true;
        document.getElementById('IdDoSeuTextboxCampo2').required = false;
        document.getElementById('IdDoSeuTextboxCampo3').required = false;
        document.getElementById('IdDoSeuTextboxCampo4').required = false;
    } else if (document.getElementById('IdDoSeuTextboxCampo2').value.length> 0) {
        document.getElementById('IdDoSeuTextboxCampo1').required = false;
        document.getElementById('IdDoSeuTextboxCampo2').required = true;
        document.getElementById('IdDoSeuTextboxCampo3').required = false;
        document.getElementById('IdDoSeuTextboxCampo4').required = false;
    } else if (document.getElementById('IdDoSeuTextboxCampo3').value.length> 0) {
        document.getElementById('IdDoSeuTextboxCampo1').required = false;
        document.getElementById('IdDoSeuTextboxCampo2').required = false;
        document.getElementById('IdDoSeuTextboxCampo3').required = true;
        document.getElementById('IdDoSeuTextboxCampo4').required = false;
    } else if (document.getElementById('IdDoSeuTextboxCampo4').value.length> 0) {
        document.getElementById('IdDoSeuTextboxCampo1').required = false;
        document.getElementById('IdDoSeuTextboxCampo2').required = false;
        document.getElementById('IdDoSeuTextboxCampo3').required = false;
        document.getElementById('IdDoSeuTextboxCampo4').required = true;
    }
}
</script>
* Você chama a função ao apertar qualquer tecla no INPUT de todos os seus INPUT
<form name='formSend' method='post' action='incluir.php' >
    <input type="text" id="IdDoSeuTextboxCampo1" onKeyUp="checkPreenchimento()" required  autofocus/>
    <input type="text" id="IdDoSeuTextboxCampo2" onKeyUp="checkPreenchimento()" required />
    <input type="text" id="IdDoSeuTextboxCampo3" onKeyUp="checkPreenchimento()" required />
    <input type="text" id="IdDoSeuTextboxCampo4" onKeyUp="checkPreenchimento()" required />
    <input type="Submit" value="Validar" /></td>
</form>
</body>
</html>

Espero ter ajudado de alguma forma.

 

Att
Felipe Guedes Coutinho

Share this post


Link to post
Share on other sites

peterstefan

Segue um exemplo caso você queira fazer com PHP apenas:

na página onde você tem os campos você vai ter apenas uma validação de uma variável PHP para exibir o erro.

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta name="keywords" content="" />
<meta name="description" content="" />
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<title>Check Campos</title>
<?php session_start();
if (!empty($_SESSION['msg_alerta'])) {
    echo "Alerta:".$_SESSION['msg_alerta'];
    $_SESSION['msg_alerta'] = "";
} ?>

<form name='formSend' method='post' action='incluir.php' >
    <input type="text" name="IdDoSeuTextboxCampo1" autofocus/>
    <input type="text" name="IdDoSeuTextboxCampo2" />
    <input type="text" name="IdDoSeuTextboxCampo3" />
    <input type="text" name="IdDoSeuTextboxCampo4" />
    <input type="submit" value="Validar">
</form>
</body>
</html>

Nesse exemplo, o ACTION do FORM chama uma página INCLUIR.PHP, nela vamos fazer a validação como mostra o código abaixo.

<?php
if (empty($_POST['IdDoSeuTextboxCampo1']) and empty($_POST['IdDoSeuTextboxCampo2']) and empty($_POST['IdDoSeuTextboxCampo3']) and empty($_POST['IdDoSeuTextboxCampo4'])) {
    session_start();
    $_SESSION['msg_alerta'] = "Você deve preencher ao menos um campo!";
    header("Location: checkCampos.php");
    exit();
};

echo "Um dos valores foi preenchido";
?>

Repare que no ECHO "UM DOS VALORES  FOI PREENCHIDO" você deve colocar o seu insert e outras validações se for necessário.

 

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 heenrique
      Boa Noite
       
      amigos tenho um select no qual me retorna o seguinte 
      SELECT * FROM sis_suporte WHERE tecnico = '1' AND abertura < '2019-10-30'; +----+--------------------------------------+------------+---------------------+---------------------+-------+---------+----------------+-----------------------------+------------------+----------------------------+---------------------+------------+--------------+-------+---------+-------------+------------------------------------------------------------------+ | id | uuid_suporte | assunto | abertura | fechamento | email | status | chamado | nome | login | atendente | visita | prioridade | ramal | reply | tecnico | login_atend | motivo_fechar | +----+--------------------------------------+------------+---------------------+---------------------+-------+---------+----------------+-----------------------------+------------------+----------------------------+---------------------+------------+--------------+-------+---------+-------------+------------------------------------------------------------------+ | 36 | 1901294b-80e6-4389-9059-fa090c09e382 | Outros | 2019-09-14 19:27:42 | 2019-10-17 19:35:20 | NULL | aberto | 14091919272653 | Alex Ramos dos Santos | alex.santos | Letícia Paula de Oliveira | 2019-10-17 16:27:15 | normal | SAO PAULO | nao | 1 | leticia | TÉCNICO HENRIQUE FINALIZOU A ORDEM: CLIENTE BLOQUEADO | | 37 | af8da3e7-9dbc-45b9-945b-d50cd45d9ea6 | Outros | 2019-09-14 19:37:13 | 2019-10-04 21:11:25 | NULL | fechado | 14091919370623 | Alexsandro Santos Braz | alesysandro.braz | Letícia Paula de Oliveira | 2019-10-04 16:37:15 | normal | SAO PAULO | nao | 1 | leticia | TÉCNICO HENRIQUE FINALIZOU A ORDEM: | | 39 | 2b03e9d4-50ca-4713-8149-88fe083fb9d9 | Instalacao | 2019-09-16 17:00:22 | 2019-10-03 22:38:23 | NULL | fechado | 16091916593665 | Henrique Gabriel de Almeida | teste | Letícia Paula de Oliveira | 2019-10-03 08:00:15 | normal | POUSO ALEGRE | sim | 1 | leticia | TÉCNICO HENRIQUE FINALIZOU A ORDEM: QWE | | 40 | b2c0fc23-0a5c-46ae-a8b8-a8641b1d53c4 | Outros | 2019-10-03 23:21:22 | 2019-10-03 23:36:51 | NULL | fechado | 03101923210987 | Henrique Gabriel de Almeida | teste | sistema | 2019-10-03 14:21:15 | normal | POUSO ALEGRE | nao | 1 | admin | TÉCNICO HENRIQUE FINALIZOU A ORDEM: RELIGUEI A FONTE DO CLIENTE | | 41 | e9aaf792-56c6-4fe1-b8c3-aa51338f65d1 | Outros | 2019-10-03 23:23:02 | 2019-10-03 23:46:01 | NULL | fechado | 03101923225491 | Cintia Rocha Vaz | cintia.vaz | sistema | 2019-10-03 17:22:15 | normal | SAO PAULO | nao | 1 | admin | TÉCNICO HENRIQUE FINALIZOU A ORDEM: 12 | +----+--------------------------------------+------------+---------------------+---------------------+-------+---------+----------------+-----------------------------+------------------+----------------------------+---------------------+------------+--------------+-------+---------+-------------+------------------------------------------------------------------+ 5 rows in set (0.00 sec) e quando imprimo sai um por um, gostaria de agrupar por data de abertura ex.
       
      2019-09-14
      Alex Ramos
      Alexsandro
       
      2019-09-16
      Henrique
       
      2019-10-03
      Henrique
      Cintia
       
      como agrupar isso em php,
       
      esse e o cod onde eu imprimo
       
      <?php while($dados = mysqli_fetch_assoc($resultado_os)){ if ($dados['status'] == 'aberto'){ ?> <div class='row'> <div class='col-md-12'> <a href='os.php?os=<?php echo $dados['chamado']; ?>'> <div style='box-shadow: 3px 3px 0px 1px rgba(0,0,0,0.1);' class='info-box'> <span class='info-box-icon1 bg-agua'><i style='padding-top: 35%;' class='ion ion-ios-gear-outline'></i></span> <div class='info-box-content'> <span class='info-box-text'><b>ABERTA</b></span> <span class='info-box-text'><b>O.S:</b><?php echo $dados['chamado']; ?></span> <span class='info-box-text'><b>NOME:</b><?php echo utf8_encode($dados['nome']); ?></span> <span class='info-box-text'><b>TIPO:</b><?php echo $dados['assunto']; ?></span> <span class='info-box-text'><b>DATA/HORA:</b><?php echo (new DateTime($dados['visita']))->format('d/m/Y - H:i'); ?></span> </a> </div> </div> <?php } if ($dados['status'] == 'fechado'){ ?> <div class='row'> <div class='col-md-12'> <a href='os.php?os=<?php echo $dados['chamado']; ?>'> <div style='box-shadow: 3px 3px 0px 1px rgba(0,0,0,0.1);' class='info-box'> <span class='info-box-icon1 bg-red'><i style='padding-top: 35%;' class="fa fa-check" aria-hidden="true"></i></span> <div class='info-box-content'> <span class='info-box-text'><b>FINALIZADA</b></span> <span class='info-box-text'><b>O.S:</b><?php echo $dados['chamado']; ?></span> <span class='info-box-text'><b>NOME:</b><?php echo utf8_encode($dados['nome']); ?></span> <span class='info-box-text'><b>TIPO:</b><?php echo $dados['assunto']; ?></span> <span class='info-box-text'><b>DATA/HORA:</b><?php echo (new DateTime($dados['fechamento']))->format('d/m/Y - H:i'); ?></span> </a> </div> </div> <?php } } ?> </div> </div> </div> </section> </div>  
    • By avelar.avelar
      Boa Tarde galera, 
       
      Preciso criar um Test de Recursividade na mesma tabela:
       
      Tabela: Biblioteca
      Campos:
      ID
      Titulo
      Descricao
      Biblioteca-ID(Foreign Key)
       
      Obrigado
    • By LRDSILVA3
      Pessoal Boa Tarde ,Tudo certo?
      Estou com um projeto para aprendizagem (já que só tenho conhecimentos de css e html) e upgrade da firma onde trabalho e não estou conseguindo salvar os valores do formulário no banco de dados,a conexão é feita porem salva todos os valores como null.
      <?php
      $servername = "192.168.1.109";
      $database = "cadastrokm";
      $username = "teste";
      $password = "123456";
      // Create connection
      $conn = mysqli_connect($servername, $username, $password, $database);
      // Check connection
      if (!$conn) {
            die("Connection failed: " . mysqli_connect_error());
      }
       
      echo "Connected successfully";
      $funcionarioKm = isset( $_POST['funcionarioKm']); 
          $veiculoKm = isset($_POST['veiculoKm']);
          $kmInicial = isset($_POST['kmInicial']);
          $kmFinal = isset($_POST['kmFinal']);
       
      $sql = "INSERT INTO km (funcionarioKm,veiculoKm,kmInicial,kmFinal) 
          VALUES ('$funcionarioKm','$veiculoKm','$kmInicial',
          '$kmFinal')";
      if (mysqli_query($conn, $sql)) {
            echo "New record created successfully";
      } else {
            echo "Error: " . $sql . "<br>" . mysqli_error($conn);
      }
      mysqli_close($conn);
      ?>
      <!DOCTYPE html>
      <html lang="pt-br">
      <head>
          <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css" integrity="sha384-MCw98/SFnGE8fJT3GXwEOngsV7Zt27NXFoaoApmYm81iuXoPkFOJwJ8ERdknLPMO" crossorigin="anonymous">
      <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
      <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js" integrity="sha384-ZMP7rVo3mIykV+2+9J3UJ46jBk0WLaUAdn689aCwoqbBJiSnjAK/l8WvCWPIPm49" crossorigin="anonymous"></script>
      <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js" integrity="sha384-ChfqqxuZUCnJSK3+MXmPNIyE6ZbWh2IMqE241rYiqJxyMiZ6OW/JmZQ5stwEULTy" crossorigin="anonymous"></script>

      </head>
      <body>
        
          <div class=container>
      <section>
          <!-- Página de Cadastro de KM -->
          <h1>Cadastro de Km</h1>
          <hr><br><br>
          <form method="post" action="conexao.php">
          <p class="font-weight-bold">Favor Selecione seu Nome:</p>
                <select id="funcionarioKm"  name="funcionarioKm"required autofocus>
                    <option>Motorista</option>
                    <option>Almir</option>
                           <option>Maykon</option>
                                      <option>Jorge</option>    
                                  </select>
      </br></br>
                <p class="font-weight-bold">Favor Selecione o Veiculo:</p>
                <select id="veiculoKm" value="veiculoKm " name="veiculoKm"required>
                    <option>Veiculo</option>
                    <option>L200</option>
                           <option>Strada 01</option>
                                      <option>Strada 02</option>    
                                      <option>Caminhão 01</option>    
                                  </select> 
       </br></br>
                 <label for="litros"><p class="font-weight-bold">Informe a Quilometragem Inicial:</p></label>
              <input type="number" id="kmInicial" name="kmInicial" required/>
      </br></br>
              <label for="litros"><p class="font-weight-bold">Informe a Quilometragem Final:</p></label>
              <input type="number" id="kmFinal" name="kmFinal" required />
      </br></br>
              <input type="submit" value="Salvar"    class="btn btn-primary btn-md">
              <input type="reset" value="Limpar"class="btn btn-primary btn-md" >
              <br><br>
      </form>
      </section>
      </div>
      </body>
      </html>
       

       
       
    • By proflupin
      criei uma página que busca alguns dados no BD e retornar em forma de collapse. Como existe um WHILE executando o collapse, ele sempre o executa com o mesmo ID, ou seja, se eu tiver 20 collapse, todos vão ser abertos ao clicar no primeiro.
      A dúvida é, como eu posso criar um novo ID para o collapse a cada loop do While?
      Código:
       
      <?php while($result_inners = mysqli_fetch_object($result_inner)){ ?> <div class="card-footer "> <a class="text-muted" data-toggle="collapse" href="#collapse1" role="button" aria-expanded="false" aria-controls="collapseExample"> <i class="fas fa-comment-alt"></i> <?php if(!empty($result_inners->nome_completo)) echo $result_inners->nome_completo . " respondeu..."; else echo "Aguardando resposta do técnico." ?> </a> <div class="collapse " id="collapse1"> <div class="bg-white mt-2 p-2"> <?php echo nl2br($result_inners->mensagem) ?> </div> <span style="color: #6c757d; float: right;"><?php echo date('d/m/Y H:i', strtotime($result_inners->data_hora)) ?></span> </div> </div> <?php } ?>  
    • By elielton
      Preciso usar um regex 
      qual expressão reconhece: 03-190325
       
       
      Alguém pode me ajudar?
       
       
×

Important Information

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