Ir para conteúdo
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..

  • +1 1

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

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar Agora

  • Conteúdo Similar

    • Por RSN
      Boa Noite, 
      Gostaria de saber se existe a possibilidade de gravar além do id do option value outra variavel, para enviar via post.
      <div class="form-group"> <label class="col-md-4 control-label" for="txtgrupo">Tipo de Pagamento : </label> <div class="col-md-4"> <select id="" class="selectpicker" data-live-search="true" name="tipo_pagamento" > <?php $query = mysql_query("SELECT * FROM tipo_pagamento ORDER BY id ASC"); while($result = mysql_fetch_array($query)) { echo '<option value="'.$result["id"].'">'.$result["nome_tipo"].'</option>'; } ?> </select> </div> </div>  
    • Por JeanTDZ
      Eu tenho um form com algumas informações etc. O form envia pro banco de dados e tudo mais, funcional.
       
      Alguém teria algum exemplo que após o submit, o form é transformado em pdf/doc e direcionado para uma pasta/ftp já criada.?
    • Por jparenque
      Pessoal, estou precisando de um código em php que faça o seguinte:

      1- acesse uma url capture e grave o código fonte
      2- acesse novamente a mesma url, capture o código fonte e compare com o código da primeira captura
      3- se o código for igual ao da primeira captura ele acessa novamente e compara novamente
      4- se o código for diferente do da primeira captura ele tem que abrir o navegador Chrome e ir para essa url através do navegador.
      5- o fim do código deverá ser apenas quando ele acessar a url encontrar um conteúdo diferente do da primeira captura.

      Vou rodar o php na máquina local. O objetivo é monitorar uma página url específica com relação à uma alteração que ocorrerá. E quando ocorrer precisarei atuar nessa página imediatamente.

      Obrigado a todos!
    • Por reisleandro
      Alguém ai conhece um servidor php portável que possa rodar direto de um pendrive e que não apresente a mensagem de bloqueio do firewall (Imagem abaxio). O servidor embutido do php faz exatamente isso mas apenas como sigle thread. Queria uma solução um pouco mais robusta que pudesse rodar em qualquer maquina sem apresentar essa mensagem. Plataforma alvo Windows.
       

    • Por JOSELUISALD
      Bom dia. Em minha aplicação o cliente quer uma cópia de seu sistema localmente e remoto (hospedado). Tem como eu fazer a sincronização dos bancos de dados, para que tudo que seja feito localmente seja inserido automaticamente no banco remoto? Desde já obrigado.
×

Informação importante

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