Autor
|
Tema: ajax recibir daros (Leído 7,818 veces)
|
jalbtercero
Desconectado
Mensajes: 80
|
Hola tengo una funciopn para recibir los datos en ajax sin actualizar la pagina solo el div, alguien me podria facilitar un codigo de ejemplo para enviar datos con ajaz sin actualizar pagina
|
|
« Última modificación: 22 Mayo 2016, 22:28 pm por jalbtercero »
|
En línea
|
|
|
|
gAb1
Desconectado
Mensajes: 731
|
JQuery tiene una función llamada serializeArray que guarda el formulario en un array con el nombre del elemento y el valor. Luego simplemente con la función post envias el array y puedes actualizar el div con la respuesta del servidor.
|
|
|
En línea
|
|
|
|
jalbtercero
Desconectado
Mensajes: 80
|
JQuery tiene una función llamada serializeArray que guarda el formulario en un array con el nombre del elemento y el valor. Luego simplemente con la función post envias el array y puedes actualizar el div con la respuesta del servidor. ok me aclarare por si acaso: Tengo dos .php 1 inserta los elemntos en la base de datos y el otro los carga en una pagina y los actualizo con ajax, lo quye quiero es con ajax enviar los datos a la base de datos sin tener que actualizar la pagina Ajax: function objetoAjax(){ var xmlhttp=false; try { xmlhttp = new ActiveXObject("Msxml2.XMLHTTP"); } catch (e) { try { xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); } catch (E) { xmlhttp = false; } } if (!xmlhttp && typeof XMLHttpRequest!='undefined') { xmlhttp = new XMLHttpRequest(); } return xmlhttp; } //Función para recoger los datos del formulario y enviarlos por post function enviarDatosEmpleado(){ divResultado = document.getElementById('contenedor'); mensaje=document.from.mensaje.value; ajax=objetoAjax(); ajax.open("POST", "ingresar.php",true); ajax.onreadystatechange=function() { if (ajax.readyState==4) { divResultado.innerHTML = ajax.responseText LimpiarCampos(); } } ajax.setRequestHeader("Content-Type","application/x-www-form-urlencoded"); ajax.send("mensaje="+mensaje); } function LimpiarCampos() { document.form.mensaje.value=""; }
ingresar.php require("connect_db.php"); $nombre = $_SESSION['usuario']; $mensaje = $_POST['mensaje']; mysql_query("INSERT INTO chat VALUES('$nombre','$mensaje')");
cargar.php <?php require("connect_db2.php"); $colo = "#320EF8"; function mostrarDatos($resultados ,$color) { if($resultados !=NULL){ echo "<p style='display: inline; color: $color; font-size: 120%; margin-left: 8px;'>".$resultados['nombre']."</p>"; echo ": "; echo $resultados['mensaje']; echo "</br>"; echo "-------------------------------------------------------------------"; echo "</br>"; } else { echo "<br/>No hay mas datos<br/>"; } } mostrarDatos($fila, $colo); }
pagina: <script language="javascript" type="text/javascript" src="enviar.js"></script> <link rel="stylesheet" type="text/css" href="chat.css"> <link rel="stylesheet" type="text/css" href="inicio.css"> <body background="fondos/fondo-inicio.jpg""> <li><a class="active" href="inicio.php">Inicio </a></li> <li><a href="paginaad.php">Administracion </a></li> <li><a href="comentarios.php">Reporta </a></li> <ul style="float:right;list-style-type:none;"> <li><a href="#about">Sobre mi </a></li> <li><a href="salir.php">Logout </a></li> <form action="" method="POST" name="form" onsubmit="enviarDatosEmpleado(); return false"> <input type="text" id="mensaje" name="mensaje"> <input type="submit" id="boton" value="Enviar">
|
|
« Última modificación: 23 Mayo 2016, 01:14 am por jalbtercero »
|
En línea
|
|
|
|
gAb1
Desconectado
Mensajes: 731
|
Te recomiendo que uses JQuery para este tipo de cosas ya que es mucho más sencillo que todo eso que estás haciendo (casi ni lo entiendo ). No necesitas usar el elemento form si vas a enviar por ajax, por lo que lo puedes quitar. Tampoco necesitas un input submit, cambialo por un anchor (y por cierto, los inputs hay que cerrarlos): <input type="text" id="mensaje" name="mensaje" /> <a id="boton" href="#">Enviar </a>
Esto sería enviar.js: $(function () { $('#boton').on('click', function () { var mensaje = $('#mensaje').val(), ajax = $.post('mensaje.php?op=1', { s: mensaje } ); ajax.done(function() { var content = $.get('mensaje.php?op=2'); $('#contenedor').empty().append( content ); $('#mensaje').val(''); }); }); });
Y esto mensaje.php (ingresar.php y cargar.php juntos): <?php require('connect_db2.php'); $op = (int) $_GET['op']; if ($op === 1) { $nombre = $_SESSION['usuario']; $mensaje = $_POST['mensaje']; mysqli_query($link, "INSERT INTO chat (nombre, mensaje) VALUES('$nombre', '$mensaje')"); } else if ($op === 2) { $color = '#320EF8'; function mostrarDatos($resultados, $color) { if($resultados !== NULL) { $mensaje = '<p style="display: inline; color: ' . $color . '; font-size: 120%; margin-left: 8px;">' . $resultados['nombre'] . ': </p>' . $resultados['mensaje'] . '<br /><hr><br />'; } else $mensaje = '<br />No hay mas datos<br />'; return $mensaje; } echo mostrarDatos($fila, $color); } } ?>
|
|
« Última modificación: 24 Mayo 2016, 02:23 am por gAb1 »
|
En línea
|
|
|
|
jalbtercero
Desconectado
Mensajes: 80
|
Te recomiendo que uses JQuery para este tipo de cosas ya que es mucho más sencillo que todo eso que estás haciendo (casi ni lo entiendo ). No necesitas usar el elemento form si vas a enviar por ajax, por lo que lo puedes quitar. Tampoco necesitas un input submit, cambialo por un anchor (y por cierto, los inputs hay que cerrarlos): <input type="text" id="mensaje" name="mensaje" /> <a id="boton" href="#">Enviar </a>
Esto sería enviar.js: $(function () { $('#boton').on('click', function () { var mensaje = $('#mensaje').val(), ajax = $.post('mensaje.php?op=1', { s: mensaje } ); ajax.done(function() { var content = $.get('mensaje.php?op=2'); $('#contenedor').empty().append( content ); $('#mensaje').val(''); }); }); });
Y esto mensaje.php (ingresar.php y cargar.php juntos): <?php require('connect_db2.php'); $op = (int) $_GET['op']; if ($op === 1) { $nombre = $_SESSION['usuario']; $mensaje = $_POST['mensaje']; mysqli_query($link, "INSERT INTO chat (nombre, mensaje) VALUES('$nombre', '$mensaje')"); } else if ($op === 2) { $color = '#320EF8'; function mostrarDatos($resultados, $color) { if($resultados !== NULL) { $mensaje = '<p style="display: inline; color: ' . $color . '; font-size: 120%; margin-left: 8px;">' . $resultados['nombre'] . ': </p>' . $resultados['mensaje'] . '<br /><hr><br />'; } else $mensaje = '<br />No hay mas datos<br />'; return $mensaje; } echo mostrarDatos($fila, $color); } } ?>
@gAb1 Gracias peroi el mensaje no se guarda en la base de datos, el nombre si pero no el mensaje
|
|
|
En línea
|
|
|
|
jalbtercero
Desconectado
Mensajes: 80
|
Y esto mensaje.php (ingresar.php y cargar.php juntos): <?php $op = (int) $_GET['op'];
No entiendo muy bien que hace esta linea esta cogiendo un valor int a traves de GET con el nombree op..
|
|
|
En línea
|
|
|
|
gAb1
Desconectado
Mensajes: 731
|
El código debería funcionar bien, no veo ningún fallo. Para este tipo de casos tienes que hacer debug: pon un alert(mensaje) en el script y mira si al hacer click en enviar se muestra el mensaje que pusiste. Si se muestra, habrá que ver si se está enviando el mensaje por post al archivo mensaje.php, para ello pon un echo $mensaje en dentro del primer if y otro alert(data) en el script enviar.js: if ($op === 1) { $nombre = $_SESSION['usuario']; $mensaje = $_POST['mensaje']; echo $mensaje;/* mysqli_query($link, "INSERT INTO chat (nombre, mensaje) VALUES('$nombre', '$mensaje')"); mysqli_close($link);*/ }
$(function () { $('#boton').on('click', function () { var mensaje = $('#mensaje').val(), ajax = $.post('mensaje.php?op=1', { s: mensaje } ); alert(mensaje); ajax.done(function(data) { alert(data);/* var content = $.get('mensaje.php?op=2'); $('#contenedor').empty().append( content ); $('#mensaje').val('');*/ }); }); });
La linea que coge el valor int en el archivo mensaje.php se utiliza para saber si vas a guardar datos en la db o vas a cogerlos. Así no necesitas tener dos archivos, solo 1.
|
|
|
En línea
|
|
|
|
AlbertoBSD
Programador y
Moderador Global
Desconectado
Mensajes: 3.705
🏴 Libertad!!!!!
|
Te comento nuevamente por aqui si hay falla en el ajax esta mandando el mensaje en una variable llamada "s".
Y en el PHP la quiee recivir con el nombre de "mensaje".
La otra es que es vulnerable a SQLinjection Por que no sanitiza sus variables de entrada.
Saludos.
|
|
|
En línea
|
|
|
|
gAb1
Desconectado
Mensajes: 731
|
Ah! Fallo mio, el copia pega xD gracias AlbertoBSD por darte cuenta. $.post('mensaje.php?op=1', { mensaje: mensaje } );
No dije nada sobre comprobar la variable porque creia que ya lo tendria controlado. De todas maneras lo pongo que no cuesta nada: Un mínimo de seguridad sería: $mensaje = filter_input(INPUT_POST , 'mensaje', FILTER_SANITIZE_STRING );
Aunque sería mucho más seguro si usaras prepared statements.
|
|
|
En línea
|
|
|
|
AlbertoBSD
Programador y
Moderador Global
Desconectado
Mensajes: 3.705
🏴 Libertad!!!!!
|
yo uso para sanitizar los inputs que van a mysql http://php.net/manual/en/mysqli.real-escape-string.phpTengo una rutina que procesa todo el array GET o POST y me ll devuelve sanitizado. Asi mismo casi no guardo valores en texto plano Solo el ID que siempre proceso con intval() los demas valores los cifro con AES o algunos valores como los passwords guardo solo guardo un substring del hash del hash del enesimo hash. Aunque tambien sirve el base64_encode etc... Al rato qur llegue a mi casa pego la funcion que uso para sanitizar todo el array. Saludos
|
|
|
En línea
|
|
|
|
|
Mensajes similares |
|
Asunto |
Iniciado por |
Respuestas |
Vistas |
Último mensaje |
|
|
[Tutorial] - Login con ajax . Mysql || Php con clases || Ajax
« 1 2 »
PHP
|
Hadess_inf
|
15
|
27,100
|
9 Diciembre 2010, 02:44 am
por delorian15
|
|
|
alguien sabe como actualizar una base de daros de wow tinity core a la 3.3.5a
Dudas Generales
|
darck113
|
0
|
2,605
|
3 Noviembre 2011, 03:18 am
por darck113
|
|
|
Recibir comunicaciones de red
Programación General
|
eb4bgr
|
0
|
1,612
|
19 Febrero 2013, 18:29 pm
por eb4bgr
|
|
|
Recibir datos a través de AJAX diferentes divs
Desarrollo Web
|
itzg3
|
4
|
2,547
|
10 Abril 2014, 22:36 pm
por itzg3
|
|
|
Daros las gracias
Foro Libre
|
flacc
|
2
|
3,075
|
22 Octubre 2022, 22:38 pm
por Danielㅤ
|
|