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
<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>
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á.
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).
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