Ir para conteúdo

POWERED BY:

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

Meetes Cadestre

Inserir e deletar tabelas via PHP, JQuery, Ajax, MySQL

Recommended Posts

Olá, estou com um problema no uso do JQuery, Ajax, PHP e MySQL. Antes de postar o código que eu fiz em si, quero explicar o que realmente quero fazer.
Eu quero fazer um sistema de favorito, mas sem contagens de favoritos. Só vai haver um botão, que lembra muito o curtir do facebook. Já pesquisei muito, tentei adaptar muitos códigos que eu li na internet, mas nenhum obtêm êxito.


Bom, vamos ao código MySQL da tabela favoritos:

CREATE TABLE IF NOT EXISTS `fav` (
    favID INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY,
    userID VARCHAR(40) NOT NULL,
    photoID INT NOT NULL
);

O JQuery:

<script src="http://code.jquery.com/jquery-1.4.4.min.js"></script>
<script>
$(function(){
		$('.pht').click(function(){
			var id = $(this).attr('rel');
                        var pgh = $(this).attr('rer');
			alert("id="+pgh+"&pht="+id+"&act=unlike");
			$.ajax({
				type: "POST",
				url: "add_likes.php",
				data: "id="+pgh+"&pht="+id,
				success: function(resposta){
					alert('Favoritado');
				}
			});
		});
	});
</script>

Aqui o código da img que ao clicar, deveria "ativar" a função javascript:

<img class ='icones post-avatar pht' src='data:image/png;base64,".base64_encode($imagem)."' width='40' height='40' rel='$pht' rer='$user'>

E, por fim, o arquivo add_likes.php:

<?php

require "init.php";
Abre_conexao();

	switch($_POST["act"]){
		case "like":
			if(@mysql_query("INSERT INTO fav VALUES (NULL,'".$_POST["id"]."' , '".$_POST["pht"]."')"){
			
			}			
		break;		
		case "unlike":
			if(@mysql_query( "DELETE FROM fav WHERE 'userID=".$_POST["id"]."' AND 'photoID=".$_POST["pht"]."'"){
			
			}
		break;		
	}
	@mysql_close();
?>

Agradeço por qualquer ajuda.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Qual problema está dando?

Compartilhar este post


Link para o post
Compartilhar em outros sites

 

o problema parece ser aqui

data: "id="+pgh+"&pht="+id,

tinha que ser um array

data: { propriedade: valor, propriedade: valor }

Atualizei o código, mas ainda não aconteceu nada para alterar ou excluir a tabela.

 

 

<script>
$(function(){
		$('.pht').click(function(){
			var id = $(this).attr('rel');
                        var pgh = $(this).attr('rer');
                        var act = $(this).attr('act');
			$.ajax({
				type: "POST",
				url: "add_likes.php",
				data: {id:id,pht:pht,act:act},
				success: function(resposta){
					alert('Favoritado');
				}
			});
		});
	});
</script>

Compartilhar este post


Link para o post
Compartilhar em outros sites

veja no console qual o retorno

firefox: F12

aba:rede

Chrome Ctrl+Shift+N

aba: network

Filtre por XHR

 

clique no botão e vai vendo o que esta errado

Compartilhar este post


Link para o post
Compartilhar em outros sites

Antes, eu estava programando no Ubuntu 14.04 com o LAMP. Agora, estou com o Windows 10, com o WAMP.
Só que agora, depois de arrumar tudo o que vcs disseram, aparece "Favoritado", mas a tabela não muda e no console não aparece nenhum erro e no network XHR, o status aparece como 200 OK

Compartilhar este post


Link para o post
Compartilhar em outros sites

Onde faz o insert?

no add_likes.php

ele recebe os parametros?

se nao

verifica o JS

se sim

a query esta certa?

parece que nao

qual o erro?

vc não vai saber pq esta suprindo o erro com arroba @

use mysql_error() pra mostrar o erro sql

pra que esse IF se ele nao faz nada, esta vazio?

if(@mysql_query("INSERT INTO fav VALUES (NULL,'".$_POST["id"]."' , '".$_POST["pht"]."')"){
  
   }

pelo navegador abra o arquivo add_likes.php ja passando os parâmetros pra vc ir testando,

vai seguindo o codigo e testando var_dump(), die() etc..

Compartilhar este post


Link para o post
Compartilhar em outros sites

Muito obrigado pela ajuda. Consegui arrumar e está totalmente funcional.
Bom, no final, ficou assim(apenas postando para que outras pessoas com o mesmo problema possam ser ajudadas)

add_likes.php

<?php
require "init.php";
Abre_conexao();

	switch($_POST["aca"]){
		case "like":
			mysql_query("INSERT INTO fav VALUES (NULL,'".$_POST["user"]."' , '".$_POST["ph"]."')");
			
 	@mysql_close();
		break;		
		case "unlike":
			mysql_query( "DELETE FROM fav WHERE fav.favID='".$_POST['ides']."'");
	@mysql_close();
		break;		
	}
	@mysql_close();
?>
<script>
$(function(){
		$('.pht').click(function(){
			var id = $(this).attr('rel');
                        var pgh = $(this).attr('rer');
                    var iu = $(this).attr('ides');
                        var act = $(this).attr('act');
			$.ajax({
				method: "POST",
				url: "add_likes.php",
				data: {user:id,ph:pgh,aca:act,ides:iu},
				success: function(resposta){
					alert('Favoritado');
				}
			});
		});
	});
</script>

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por ILR master
      Tudo bem pessoal?
       
      No código abaixo, estou fazendo uma consulta nas tabelas, banners e banners_referencia
      Meu objetivo é trazer resultados com valores iguais ao nome da cidade declarada na $cidade ou resultados com a referencia Total.
      O problema é que está trazendo todos os resultados. Tenho 10 linhas, 1 com o nome da cidade e duas com o valor Total, então o resultado teria que ser de apenas 3 linhas, mas mostra tudo.
       
      $banner = "SELECT A.*, B.* FROM banners A, banners_referencia B WHERE B.cod_referencia = A.cod_referencia AND A.cidade = '$cidade' OR B.referencia = 'Total' ORDER BY RAND()";
      $banner = mysqli_query($conexao, $banner) or die ("Banner não encontrado");
      while($busca= mysqli_fetch_array($banner)){
          print $busca['cidade'].'<br>';
      };
       
      Alguém consegue me ajudar?
    • Por Rafael_Ferreira
      Não consigo carregar a imagem do captcha do meu formulário. Foi testado com o xampp e easyphp. Também não carregou a imagem de outros captcha. 
       
       
    • Por luiz monteiro
      Olá, tudo bem?
       
      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á.
       
       
    • Por daemon
      Boa tarde,
       
      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).
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.