Usamos cookies para medir audiência e melhorar sua experiência. Você pode aceitar ou recusar a qualquer momento. Veja sobre o iMasters.
Olá, supondo que eu tenho um site de anúncios, e nesse site há uma página chamada página1.php por exemplo, nessa página tenho um input text, onde realizo uma busca a anúncios do site. Digamos que eu digitei macaco no input, ele realizará uma busca e me retornará anúncios referentes a essa busca. Então sou redirecionado a uma página (busca.php) e lá aparecem 2 anúncios -macaco alado e macaco de briga- e eu peguei a pesquisa do banco e exibi titulo, imagem e etc com apenas um código utilizando estrutura de repetição. E se eu clicar em um anuncio eu vou para a pagina dele (pag-anuncio.php). Aí está o problema não consigo enviar o código da busca para a pag-anuncio nem por SESSION nem por input hidden, na verdade eu consigo porem vai sempre o código do ultimo anuncio - no caso do exemplo mesmo se eu clicar no Macaco alado ele envia o cod do macaco de briga-. Não há necessidade de código então obrigado.
Não deu certo, porque como chama tudo no mesmo lugar so alterando por while, ele manda vários tipo um array. na minha pesquisa aqui me deu 4 resultados e eu cliquei no primeiro (id = 21) porem ele mandou todos e pegou o ultimo -> pag-anuncio2.php?id=21%2F&id=15%2F&id=12%2F&id=2%2F
no caso ele pegou o id 2 mesmo eu clicando no 21 sacou?
Com certeza existe um sério problema de lógica no seu sistema, sem ver o script é impossível adivinhar o que você fez de errado.
Com certeza existe um sério problema de lógica no seu sistema, sem ver o script é impossível adivinhar o que você fez de errado.
OK, aqui tem a repetição mandando por get, depois da consulta:
while ($resultado = mysql_fetch_assoc($query)) {
$titulo = $resultado['titulo'];
$texto = $resultado['descricao'];
$imagem = $resultado['img_princ'];
$usu_id = $resultado['usuarios_id'];
$id = $resultado['id'];
echo $id;
$sql_select_usu = mysql_query("SELECT * FROM usuarios WHERE id = $usu_id ");
$result_usu = mysql_fetch_array($sql_select_usu)or die(mysql_error());
echo"<div id='anuncio-1'>";
$caminho ="uploads/";
echo"<div class='anunciante'>";
echo" Anuncio feito por: " . $result_usu['nome'] ;
echo" </div>";
echo" <div class='col-xs-6 col-md-3'>";
echo"<form action='pag-anuncio2.php' method='GET' name='formaa'>";
echo"<input type='hidden' name='id' value=".$id."/>";
echo" <a href='#' onclick='document.formaa.submit(); return false;' class='thumbnail'>";
echo "<img src=" . $caminho . $imagem . ">" ;
echo" </a>";
echo" </div>";
echo "<div class='t-d'><h3>";
echo "<a href='#' onclick='document.formaa.submit(); return false;'>" . $titulo . "</a><br><br><br>";
echo "</h3>";
echo "<p class='um-p2' style='bottom:5%'>" . "Descrição:" . "</p>";
echo "<p class='um-p'>" .substr_replace($texto, ' ...', 60)."</p>";
echo "</div>";
echo"</div>";}
Ai tipo tentei pelo get enviando pra cá:
$id= $_GET['id'];
$sql_select = mysql_query("SELECT * FROM anuncio WHERE id='$id'");
$result = mysql_fetch_array($sql_select)or die(mysql_error());
Isso ai é o essencial, e ele realiza a consulta com o id do ultimo anuncio da pesquisa.
Tu criou um formulário somente para enviar por GET, sendo que um link faz isso.
E o seu problema realmente é o formulário, pois no while ele irá ficando se repetindo (com o mesmo nome). Ao clicar no link, ele procura um formulário com o nome "formaa". Por isso, ao clicar em qualquer link, ele envia apenas o primeiro formulário.
Faça assim:
while(/ sua condição /) {
echo '<a href="[http://link.com.br/pagina.php?id='.$id.'](http://link.com.br/pagina.php?id=)"' title="título" >título</a>';
}
o resto é só adaptar ao seu código.
Deu certo!!!!!!!! Valeu mano se é demais
Input hidden somente é enviado por submit de formulário. SESSION não faz muito sentido, pois ele não sabe o que você vai clicar.
Adicione o código ao link do anúncio
http://site.com.br/pagina.php?codigo=1