Foros del Web » Programando para Internet » PHP »

Ayuda con esta función

Estas en el tema de Ayuda con esta función en el foro de PHP en Foros del Web. Buenas, quisiera saber si ésta función que hice, podría darle otra utilidad: en vez de verificar los usuarios que están logeados en la página, verificar ...
  #1 (permalink)  
Antiguo 06/02/2011, 23:41
 
Fecha de Ingreso: septiembre-2009
Mensajes: 230
Antigüedad: 14 años, 6 meses
Puntos: 2
Ayuda con esta función

Buenas, quisiera saber si ésta función que hice, podría darle otra utilidad: en vez de verificar los usuarios que están logeados en la página, verificar TODOS los usuarios de la db, estén logeados o no:

Código PHP:
function actividad_usuario($date_time$date_day$user$conexion) {
    
// Buscamos el valor registrado y verificamos que no sea el mismo al pasado
$query "SELECT * FROM `usuarios` WHERE nickname = '$user'";
$resultado mysql_query ($query$conexion);
$row mysql_fetch_array ($resultado);
$date_t $row['act_time'];
$date_d $row['act_day'];
$status_f $row['status'];

// Verificamos que la actividad final sea del mismo dia
if($date_day == $date_d) {
// Calculamos el tiempo de inactividad
$r_1 time() - 3600;
//$date_final = $date_time - $date_t;
$date_a date('Hi'$r_1);
$date_b $date_t;
$date_final $date_b $date_a;
// Verificamos que no haya transcurrido más de una hora
if ($date_final <= 100 && $date_final >= 0) {
$query  "UPDATE `usuarios` set status = 'Conectado', act_day = '$date_day', act_time = '$date_time' WHERE nickname = '".$user."'";
$result mysql_query($query$conexion);
}
//if dateb
else {
$query  "UPDATE `usuarios` set status = 'Desconectado' WHERE nickname = '".$user."'";
$result mysql_query($query$conexion);
session_unset();
session_destroy();
}
//else
}/*$dateday == dated */ else {
$query  "UPDATE `usuarios` set status = 'Desconectado' WHERE nickname = '".$user."'";
$result mysql_query($query$conexion);
session_unset();
session_destroy();
}


Estuve pensando nuevamente como podría modificarla, pero, si le saco los WHERE nickname, editaría a TODAS las filas, y lo que quiero, es editar nada mas a las que no cumplan la función del tiempo! Saludos y gracias de ante mano.
  #2 (permalink)  
Antiguo 07/02/2011, 00:01
 
Fecha de Ingreso: diciembre-2010
Mensajes: 788
Antigüedad: 13 años, 4 meses
Puntos: 51
Respuesta: Ayuda con esta función

Por lo que veo en tu función, si no me equivoco, es que estás usando la hora tipo "H:i:s" o algo similar en el campo que guardás en tu db. Lo mejor sería que guardes el timestamp actual cuando el usuario genera actividad, con time() de PHP. Y luego solo sería cuestión de hacer algo así:

Código PHP:
Ver original
  1. $rangoTiempo = time() - 3600;
  2.  
  3. $query  = "UPDATE `usuarios` set status = 'Desconectado' WHERE act_time < $rangoTiempo";
  #3 (permalink)  
Antiguo 07/02/2011, 10:12
 
Fecha de Ingreso: septiembre-2009
Mensajes: 230
Antigüedad: 14 años, 6 meses
Puntos: 2
Respuesta: Ayuda con esta función

y para Conectados hago lo contrario? Y actualizo el act time?
  #4 (permalink)  
Antiguo 07/02/2011, 13:53
 
Fecha de Ingreso: diciembre-2010
Mensajes: 788
Antigüedad: 13 años, 4 meses
Puntos: 51
Respuesta: Ayuda con esta función

Cita:
Iniciado por kirst Ver Mensaje
y para Conectados hago lo contrario? Y actualizo el act time?
Sería algo así:

Código PHP:
Ver original
  1. $ahora = time();
  2. $rangoTiempo = $ahora - 3600;
  3.  
  4. $query  = "UPDATE `usuarios` set status = 'Conectado', act_time = '".$ahora."' WHERE act_time +3600 >= $rangoTiempo";

Etiquetas: Ninguno
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 13:58.