Foros del Web » Programando para Internet » PHP »

Eliminar COOKIE's

Estas en el tema de Eliminar COOKIE's en el foro de PHP en Foros del Web. Bien, creo que esto es algo absurdo ya a estas alturas de mi carrera. Estoy haciendo un blog desde cero y todo perfecto, no quiero ...
  #1 (permalink)  
Antiguo 20/07/2011, 23:06
danneg
Invitado
 
Mensajes: n/a
Puntos:
Eliminar COOKIE's

Bien, creo que esto es algo absurdo ya a estas alturas de mi carrera.

Estoy haciendo un blog desde cero y todo perfecto, no quiero que ningun detalle se me vaya de las manos ni nada; para controlar mi blog, obviamente debo de ser un usuario registrado, y todo bien, pero cuando trato de cerrar seción, he ahi el problema... simplemente no lo hace.

para verificar que existe una seción tengo esta función:

Código PHP:
Ver original
  1. function check_login(){
  2.     session_start();
  3.     $login_status = false;
  4.     if ( isset($_COOKIE['DANNEGMSESSIONID']) ){
  5.         $_SESSION["login"] = true;
  6.         $_SESSION["s_id"] = base64_decode($_COOKIE['DANNEGMSESSIONID']);
  7.         $login_status = true;
  8.     }
  9.     if ( isset($_SESSION["login"]) ){
  10.         if ( $_SESSION["login"] == true ){
  11.             $login_status = true;
  12.         }
  13.     }
  14.     return $login_status;
  15. }

Y hasta ahi todo bien...

Para terminar la seción uso esto:

Código PHP:
Ver original
  1. $_SESSION["login"] = false;
  2. $_SESSION["s_id"] = null;
  3. unset($_COOKIE['DANNEGMSESSIONID']);
  4. header("location: ../index.php");

Ahi es donde tengo el problema, hasta donde yo sabia, unset($_COOKIE['DANNEGMSESSIONID']); eliminaba la COOKIE, pero a mi no me elimina, ahi queda, y al quedarse ahi, como veran en mi verificacion del login, si detecta la COOKIE se habre la seción.

Igual lei en iternet que cambiando la cookie de valor ( setcookie ) lo podia hacer, el problema es que no sobre escribe tampoco el valor, sino que escribe una cookie nueva con el mismo nombre O_O

Ahora, a lo que voy, alguna sugerencia de como eliminar una cookie?

(Tanto rollo para una simple pregunta XD) ... disculpen las molestias y gracias de antemano!

PD. Pueden testear pos ustedes mismos el comportamiento desde http://dannegm.com y con el usuario ( User: demo, Pass: demo) o podrian crearse un nuevo usuario.
  #2 (permalink)  
Antiguo 20/07/2011, 23:34
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: Eliminar COOKIE's

Para eliminar realmente una cookie debes establecer su fecha de expiración como que ya paso.

¿Se te olvidó consultar el manual al respecto?
http://php.net/setcookie
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #3 (permalink)  
Antiguo 21/07/2011, 00:07
danneg
Invitado
 
Mensajes: n/a
Puntos:
Respuesta: Eliminar COOKIE's

no no se me olvido, fue el primer lugar a donde fui, pero como menciono, al declarar de nuevo setcookie no cambia valores de nada, si no clona la cookie.

al menos eso me pasa a mi
  #4 (permalink)  
Antiguo 21/07/2011, 00:46
 
Fecha de Ingreso: junio-2011
Mensajes: 25
Antigüedad: 12 años, 9 meses
Puntos: 8
Respuesta: Eliminar COOKIE's

Cita:
Iniciado por danneg Ver Mensaje
no no se me olvido, fue el primer lugar a donde fui, pero como menciono, al declarar de nuevo setcookie no cambia valores de nada, si no clona la cookie.

al menos eso me pasa a mi
Hola, intentaste en logout poner algo asi

Código PHP:
setcookie("DANNEGMSESSIONID","/",time()-100); 
o mas bien asi

Código PHP:
Ver original
  1. setcookie("DANNEGMSESSIONID", "", time()-3600, "/")
  #5 (permalink)  
Antiguo 21/07/2011, 01:17
danneg
Invitado
 
Mensajes: n/a
Puntos:
Respuesta: Eliminar COOKIE's

ok muchas gracias por sus respuestas!.. esa ultima solucion me seguia clonando la cookie, me aparecian 2, y una mas cada que ejecutaba el logout

En fin, decidi cambiar un poco el login y logout y quedo asi

check_login:

Código PHP:
Ver original
  1. <?php
  2. function check_login(){
  3.     session_start();
  4.     $login_status = false;
  5.     if ( isset($_COOKIE['DANNEGMSESSIONID']) ){
  6.         if( !$_COOKIE['DANNEGMSESSIONID'] == "false"){
  7.             $_SESSION["login"] = true;
  8.             $_SESSION["s_id"] = base64_decode($_COOKIE['DANNEGMSESSIONID']);
  9.             $login_status = true;
  10.         }
  11.     }
  12.     if ( isset($_SESSION["login"]) ){
  13.         if ( $_SESSION["login"] == true ){
  14.             $login_status = true;
  15.         }
  16.     }
  17.     return $login_status;
  18. }
  19. ?>

logout:

Código PHP:
Ver original
  1. <?php
  2. $_SESSION["login"] = false;
  3. $_SESSION["s_id"] = null;
  4. if ( isset($_COOKIE['DANNEGMSESSIONID']) ){
  5.     $_COOKIE['DANNEGMSESSIONID'] = "false";
  6. }
  7. header("location: ../index.php");
  8. ?>

No elimine la cookie, cambie valores, pero no utilize setcookie para ello...

Muchas gracias por sus respuestas! y disculpen las molestias

Última edición por danneg; 21/07/2011 a las 01:18 Razón: resalte mal el codigo
  #6 (permalink)  
Antiguo 21/07/2011, 02:06
 
Fecha de Ingreso: junio-2011
Mensajes: 25
Antigüedad: 12 años, 9 meses
Puntos: 8
Respuesta: Eliminar COOKIE's

Que raro a mi si me borra la cookie de tu pagina cuando le doy logout, tienes proteccion en la cookie? porque si la edito y le quito el false, me puedo logear
  #7 (permalink)  
Antiguo 22/07/2011, 13:54
danneg
Invitado
 
Mensajes: n/a
Puntos:
Respuesta: Eliminar COOKIE's

pues entonces ya es onda de mi navegador, aun asi esta solucionado en mi navegador y cualquier otro eso del logout.

sobre lo que me dice de cambiar el valor de la cookie, puedes hacerlo, solo que para obtener tus datos debes saber el valor exacto que tenia la cookie

y gracias por la ayuda ;)

Etiquetas: cookie, dannegm, session
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 11:12.