Foros del Web » Programando para Internet » PHP »

Hacer que un Sistema de Comentarios sea para Varias Paginas

Estas en el tema de Hacer que un Sistema de Comentarios sea para Varias Paginas en el foro de PHP en Foros del Web. Tengo un pequeño problema. He buscado la solución en el foro y en la web y creo que estoy haciendo lo correcto pero hace falta ...
  #1 (permalink)  
Antiguo 02/01/2013, 14:58
Avatar de franco9090  
Fecha de Ingreso: diciembre-2012
Ubicación: Medellin
Mensajes: 10
Antigüedad: 11 años, 3 meses
Puntos: 0
Mensaje Hacer que un Sistema de Comentarios sea para Varias Paginas

Tengo un pequeño problema. He buscado la solución en el foro y en la web y creo que estoy haciendo lo correcto pero hace falta algo, y me gustaría que alguno me pudiera ayudar con ello si es posible.

tengo las siguientes paginas:

Pagina_ventas.php

pagina_muestras.php

blog_clientes.php

He descargado un sistema de comentarios muy chulo pero que solo trabaja con una pagina, es decir, si yo lo incluyera en esas tres paginas saldrían los mismos comentarios en las tres.
El sistema de comentarios tiene los siguientes archivos:

comentarios.php //Contiene el form y muestra los comentarios que se van añadiendo.


Código PHP:
<?php
$id_of_page 
1;
// Error reporting:
error_reporting(E_ALL^E_NOTICE);

include 
"comentarios/connect.php";
include 
"comentarios/comentarios.clase.php";


/*
/    Select all the comments and populate the $comments array with objects
*/

$comments = array();
$result mysql_query("SELECT * FROM comments WHERE id_page=".$id_of_page." ORDER BY id ASC");

while(
$row mysql_fetch_assoc($result))
{
    
$comments[] = new Comment($row);
}

?>


<link rel="stylesheet" type="text/css" href="<?php echo BASE_URL?>comentarios/styles.css" />





<?php

/*
/    Output the comments one by one:
*/

foreach($comments as $c){
    echo 
$c->markup();
}

?>

<div id="addCommentContainer">
    <p>Agrega un Comentario</p>
    <form id="addCommentForm" method="post" action="">
        <div>
            <label for="name">Tu Nombre</label>
            <input type="text" name="name" id="name" />
            
            <label for="email">Tu Email</label>
            <input type="text" name="email" id="email" />
            
            <label for="url">Sitio Web (No obligatorio)</label>
            <input type="text" name="url" id="url" />
            
            <label for="body">Comentario o Mensaje</label>
            <textarea name="body" id="body" cols="20" rows="5"></textarea>
            
            <input type="hidden" name="id_page" id="id_page" value="<?php echo $id_of_page?>" />
            
            <input type="submit" id="submit" value="Enviar" />
        </div>
    </form>
</div>



<script type="text/javascript" src="<?php echo BASE_URL?>comentarios/script.js"></script>

submit.php // Envía la información a la base de datos.

Código PHP:
<?php


// Error reporting:
error_reporting(E_ALL^E_NOTICE);

include 
"connect.php";
include 
"comentarios.clase.php";


/*
/    This array is going to be populated with either
/    the data that was sent to the script, or the
/    error messages.
/*/

$arr = array();
$validates Comment::validate($arr);

if(
$validates)
{
    
/* Everything is OK, insert to database: */
    
    
mysql_query("    INSERT INTO comments(name,url,email,body,id_page)
                    VALUES (
                        '"
.$arr['name']."',
                        '"
.$arr['url']."',
                        '"
.$arr['email']."',
                        '"
.$arr['body']."',
                        '"
.$id_of_page."'
                    )"
);
    
    
$arr['dt'] = date('r',time());
    
$arr['id'] = mysql_insert_id();
    
    
/*
    /    The data in $arr is escaped for the mysql query,
    /    but we need the unescaped variables, so we apply,
    /    stripslashes to all the elements in the array:
    /*/
    
    
$arr array_map('stripslashes',$arr);
    
    
$insertedComment = new Comment($arr);

    
/* Outputting the markup of the just-inserted comment: */

    
echo json_encode(array('status'=>1,'html'=>$insertedComment->markup()));

}
else
{
    
/* Outputtng the error messages */
    
echo '{"status":0,"errors":'.json_encode($arr).'}';
}

?>
Como pueden ver lo que hice fue hacer un identificador a cada pagina donde quiero que salgan comentarios de la siguiente manera :
Código PHP:
$id_of_page 1;
$id_of_page 2
y asi sucesivamente.
Luego en la base de datos añadí un nuevo campo que se llama id_page y cambié la consulta en comentarios.php asi:

Código PHP:
$comments = array();
$result mysql_query("SELECT * FROM comments WHERE id_page=".$id_of_page." ORDER BY id ASC"); 
En el form agregue el nuevo valor asi:

Código PHP:
<input type="hidden" name="id_page" id="id_page" value="<?php echo $id_of_page?>" />
Y finalmente en submit.php, agregue el campo en el INSERT asi:

Código PHP:
mysql_query("    INSERT INTO comments(name,url,email,body,id_page)
                    VALUES (
                        '"
.$arr['name']."',
                        '"
.$arr['url']."',
                        '"
.$arr['email']."',
                        '"
.$arr['body']."',
                        '"
.$id_of_page."'
                    )"
);
    
    
$arr['dt'] = date('r',time());
    
$arr['id'] = mysql_insert_id(); 
En mi novato concepto esto ya debería funcionar, pero bien dicho soy novato.
Así que no me están llegando los valores de las variables a la base datos y por ende al refrescar la pagina se borran los comentarios, ya que quedan con valor '0' en el campo id_page en la tabla.

Se que algo muy pequeño esta faltándome para que todo trabaje bien, pero aun no descubro que es .
Encima luego debo lograr que cada noticia nueva en blog_clientes.php tenga sus propios comentarios.
Les agradecería enormemente si alguno me puede orientar.
Un Saludo.

Última edición por franco9090; 02/01/2013 a las 17:27
  #2 (permalink)  
Antiguo 03/01/2013, 09:09
Avatar de enlinea777  
Fecha de Ingreso: mayo-2008
Ubicación: frente al pc
Mensajes: 1.830
Antigüedad: 15 años, 10 meses
Puntos: 127
Respuesta: Hacer que un Sistema de Comentarios sea para Varias Paginas

No tengo idea de lo que estas haciendo, y me da lata perder el tiempo leyendo y entendiando el codigo, pero si se como lo haria yo.

dices que el sistema de cometarios sirve para una pagina ok.

lo que haria seria que a cada comentario le adjuntaria el id de cada noticia a cada comentario para filtrar por noticia y mostrar solo los comentarios de cada noticia, asimismo con Pagina_ventas.php, pagina_muestras.php, blog_clientes.php a cada pagina le daria un ID para poder ingresarlo junto con la noticia y asi poder filtrar cuando llamo los comentarios de cada cosa.
si tienes tiempo podria enseñarte como.
  #3 (permalink)  
Antiguo 03/01/2013, 09:30
Avatar de franco9090  
Fecha de Ingreso: diciembre-2012
Ubicación: Medellin
Mensajes: 10
Antigüedad: 11 años, 3 meses
Puntos: 0
Respuesta: Hacer que un Sistema de Comentarios sea para Varias Paginas

Por supuesto. Tengo todo el tiempo del mundo y te agradezco tu amabilidad.
Fíjate que a cada página como dices le he puesto su id asi:

Pagina_ventas.php // $id_of_page = 1;

pagina_muestras.php // $id_of_page = 2;

Y así por el estilo, y por supuesto cada una con su respectivo form que manda los estos valores por medio de un input asi:

<input type="hidden" name="id_page" id="id_page" value="<?php echo $id_of_page; ?>" />

y en la pagina submit.php, que es la que hace el INSERT puse el valor así:

mysql_query(" INSERT INTO comments(name,url,email,body,id_page)
VALUES (
'".$arr['name']."',
'".$arr['url']."',
'".$arr['email']."',
'".$arr['body']."',
'".$id_of_page."'//<---// lo ves acá?
)");

$arr['dt'] = date('r',time());
$arr['id'] = mysql_insert_id();

Pero en la tabla el campo id_page esta saliendo con valor '0' en lugar de con los valores que le asigno en las variables id_of_page, y ese es precisamente el problema que tengo.

Espero haber sido lo suficientemente claro.
Gracias de nuevo.
  #4 (permalink)  
Antiguo 03/01/2013, 10:00
Avatar de enlinea777  
Fecha de Ingreso: mayo-2008
Ubicación: frente al pc
Mensajes: 1.830
Antigüedad: 15 años, 10 meses
Puntos: 127
Respuesta: Hacer que un Sistema de Comentarios sea para Varias Paginas

ok ahora que te explicas mejor se como ayudarte.

primero pon el campo del input pon text en lugar de hidden para ver si esta colocando el id

ahora en la pagina submit.php, como estas recojiendo los valores por GET o por POST? creo que aqui tienes el problema.

supongo que tienes que poner algo como

mysql_query(" INSERT INTO comments(name,url,email,body,id_page)
VALUES (
'".$arr['name']."',
'".$arr['url']."',
'".$arr['email']."',
'".$arr['body']."',
'".$arr['id_page']."'//<---// acá
)");
  #5 (permalink)  
Antiguo 03/01/2013, 12:07
Avatar de franco9090  
Fecha de Ingreso: diciembre-2012
Ubicación: Medellin
Mensajes: 10
Antigüedad: 11 años, 3 meses
Puntos: 0
Respuesta: Hacer que un Sistema de Comentarios sea para Varias Paginas

Hola.
He hecho todo lo que me sugeriste.
He cambiado el input hidden por text, y efectivamente muestra el valor de la variable.

Tambien cambie los valores en el INSERT asi:

mysql_query(" INSERT INTO comments(name,url,email,body,id_page)
VALUES (
'".$arr['name']."',
'".$arr['url']."',
'".$arr['email']."',
'".$arr['body']."',
'".$arr['id_page']."'//<---// acá
)");

Y he intentado cuanta cosa se me acurre, pero aun no tengo resultados .
Siento que voy a enloquecer, te agradecería muchísimo si puedes colaborarme un poco mas.
Gracias de nuevo.

Etiquetas: comentarios
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 05:44.