
Modelo básico para iniciar o desenvolvimento de um sistema de busca com filtros no PHP.
Este é um exemplo básico de código para você iniciar o desenvolvimento de um sistema de busca com filtros no PHP.
Com varias dicas de funções para que você crie um código seguro, objetivo deste conteúdo é acadêmico.
Por que GET? $_GET é um array associativo de variáveis passadas para o script atual via o método HTTP GET.
Exemplo: https://rogertakemiya.com.br?nome=Roger
Já para tratar os valores enviados pelos campos utilizamos a função addslashes().
addslashes: Retorna uma string com barras invertidas antes de caracteres que precisam ser tratados para serem colocados em um query no banco de dados, etc. Estes caracteres são aspas simples (‘), aspas duplas (“), barra invertida (\) e NUL.
Vamos ao código, na primeira parte recebemos os valores via GET e criamos as validações necessárias
<?php
$nome = addslashes($_GET['nome']);
$idade = addslashes($_GET['idade']);
$email = addslashes($_GET['email']);
if(!is_null($nome) && !is_null($idade) && !is_null($email)){
echo "Todos os campos estão enviando valor";
}else{
echo "Algum campo nao esta correto";
}
?> Para validar se os valores foram informados e enviados, utilizo a função is_null(), que verifica se uma variável é NULL “não foi definida”.
Em situações similares você também pode estar utilizando as funções empty() ou isset() para verificar o preenchimento dos valores.
empty: determina se uma variável é considerada vazia. Uma variável é considerada vazia se não existir ou seu valor é igual FALSE. A função empty() não gera um aviso se a variável não existir.
isset: irá verificar se a variável informada foi definida, possuí um valor, mesmo que vazio e irá retornar TRUE se sim ou FALSE caso contrário.
Para conectar ao banco de dados utilizamos a extensão PDO, segue o exemplo:
$user = "usuario";
$pass = "senha";
$dbh = new PDO('mysql:host=localhost;dbname=test', $user, $pass); PDO: A extensão PDO (PHP Data Objects) define uma interface leve e consistente para acessar diversos tipos de bancos de dados no PHP.
Agora preparamos a nossa Query “consulta” ao banco de dados.
Atenção: Repare na utilização do bindParam() para evitar ataques de SQL Injection.
$sql = $pdo->prepare("SELECT nome, idade, email FROM usuarios WHERE nome = :nome AND idade = :idade AND email = :email");
$sql->bindParam(':nome', $nome, PDO::PARAM_STR);
$sql->bindParam(':idade', $nome, PDO::PARAM_INT);
$sql->bindParam(':email', $email, PDO::PARAM_STR);
$sql->execute();
$linha = $sql->fetch(PDO::FETCH_ASSOC);
print_r($linha);
?> A utilização da função bindParam é essencial.
bindParam: Vincula uma variável PHP a um correspondente marcador de ponto de interrogação ou nome de pergunta na instrução SQL que foi usada para preparar a declaração (ler mais).
Módulo gratuito Roger_CnpjAlfanumerico que aplica máscara e validação do novo CNPJ alfanumérico no checkout e formulários do Magento 2 e…
A partir de 06/07/2026 a Receita passa a emitir CNPJ alfanumérico. Conheça o plugin grátis que aplica máscara e validação…
Para remover um módulo do Magento 2, siga os passos abaixo: 1. Desabilitar o módulo Primeiro, desabilite o módulo usando…
Para cancelar 100% do pedido e criar um crédito para todos os itens através da API REST do Magento 2,…
No Magento 2, a quantidade "reservada" na "Salable Quantity" é gerenciada principalmente pelos módulos MSI (Multi-Source Inventory). A "Salable Quantity"…
Como corrigir o erro ao acessar o Admin do Magento 2. Mesmo após fazer o login, permanece na tela de…