Foros del Web » Programando para Internet » PHP »

Al dejar la pagina

Estas en el tema de Al dejar la pagina en el foro de PHP en Foros del Web. como hago que al usuario dejar la pagina se edite un dato en la base de datos, que se ponga su estado como desconectado... Sau2......
  #1 (permalink)  
Antiguo 18/07/2009, 18:10
 
Fecha de Ingreso: julio-2009
Mensajes: 9
Antigüedad: 14 años, 9 meses
Puntos: 0
Al dejar la pagina

como hago que al usuario dejar la pagina se edite un dato en la base de datos, que se ponga su estado como desconectado...

Sau2...
  #2 (permalink)  
Antiguo 18/07/2009, 19:31
Avatar de bioxido  
Fecha de Ingreso: diciembre-2008
Ubicación: $_SERVER['PHP_SELF']
Mensajes: 601
Antigüedad: 15 años, 4 meses
Puntos: 21
Respuesta: Al dejar la pagina

.... se supone que cuando el usuario se deslogea, se ejecuta un script o una funcion para borrar las seciones que se creo cuando se logeo.... en el mismo script podrias hacer una query haciendo UPDATE a la tabla en donde se guarda el estado del usuario, y cambiarlo a ONLINE por OFFLINE....

Ya respondi algo como esto... no creen temas sin siquiera buscar o bien, lean las respuestas de sus temas ...
  #3 (permalink)  
Antiguo 19/07/2009, 02:11
 
Fecha de Ingreso: julio-2009
Mensajes: 9
Antigüedad: 14 años, 9 meses
Puntos: 0
Respuesta: Al dejar la pagina

Esa no es la respuesta que busco, pk eso ya lo se, pero en mi caso estoy hablando de cuando un usuario no se desconecta manualmente, sino que simplemente cierra el explorador o se va a otra pagina...
salu2
  #4 (permalink)  
Antiguo 19/07/2009, 20:37
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 17 años, 11 meses
Puntos: 2135
Respuesta: Al dejar la pagina

Para eso tienes que guardar la fecha/hora de su ultima actividad, y con un cron job o tarea programada (depende de tu sistema operativo) compruebas si esa actividad es mayor a lo predefinido y en base a eso lo deslogueas.

Saludos.
  #5 (permalink)  
Antiguo 20/07/2009, 01:58
 
Fecha de Ingreso: julio-2009
Mensajes: 9
Antigüedad: 14 años, 9 meses
Puntos: 0
Respuesta: Al dejar la pagina

no tengo ni idea de como hacer eso, alguien me podria dar una idea?
  #6 (permalink)  
Antiguo 20/07/2009, 08:05
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 17 años, 11 meses
Puntos: 2135
Respuesta: Al dejar la pagina

Primero creas un script PHP donde lances una consulta y veas los usuarios que su tiempo de inactividad sea mayor a lo definido, esto lo puedes hacer con un DATE_DIFF a esos usuarios con un UPDATE les cambias el campo de conectado de 0 a 1.

Ya que tengas tu script probado y ejecutandose correctamente, lo registras en un Cron Job o Tarea Programada para que se ejecute cada 10 minutos o el tiempo que tu creas conveniente para que vaya sacando a los usuarios que cierren el explorador solamente.

Saludos.
  #7 (permalink)  
Antiguo 20/07/2009, 10:55
 
Fecha de Ingreso: enero-2009
Mensajes: 408
Antigüedad: 15 años, 3 meses
Puntos: 14
Respuesta: Al dejar la pagina

tiene que usar una funcion javascript en el evento unload del body , dicha funcion podrias usar con ajax que al ejecutarse haga un llamado con un parametro del nombre del usuario logueado via GET.

algo asi ponele:

<html>
<head></head>
<body unload="javascript:user_logout('<?php echo $_SESSION['username'] ?>')">
</body>
</html>

donde con php imprimo $_SESSION['username'] , seria donde se aloja el nombre del usuartio logueado en tu sesion php.

La funcion internamente llamaria a un script php que actualiza al estado offline de la tabla de usuarios mediante el parametro username.

La consulta sql que deberias hacer es algo asi:

UPDATE usuarios SET estado_usuario='offline' WHERE username="{$username}"

Saludos.

PD: para manejar el ajax y demas fijate simplejs o prototype :)
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 07:26.