Foros del Web » Programando para Internet » PHP »

Problema con sesiones

Estas en el tema de Problema con sesiones en el foro de PHP en Foros del Web. Hola! Estoy viendo un manual de sesiones, y al hacer uno de los ejemplos, no me muestra el valor de una variable de sesión. ¿Por ...
  #1 (permalink)  
Antiguo 21/06/2010, 11:17
 
Fecha de Ingreso: julio-2008
Mensajes: 62
Antigüedad: 15 años, 8 meses
Puntos: 0
Problema con sesiones

Hola!

Estoy viendo un manual de sesiones, y al hacer uno de los ejemplos, no me muestra el valor de una variable de sesión. ¿Por qué puede ser? Os adjunto el código:

Para crear la variable:

<?php
session_start();
?>
<html>
<head>
<title>Generar variable de sesión</title>
</head>
<body>
<?php
$_SESSION["mivariabledesesion"] = "Hola, este es el valor de la variable de sesión";
?>
</body>
</html>

Para mostrar el valor de la variable:

<?php
session_start();
?>
<html>
<head>
<title>Leo variable de sesión</title>
</head>
<body>
Muestro esa variable:
<?php
echo $_SESSION["mivariabledesesion"];
?>
</body>
</html>
  #2 (permalink)  
Antiguo 21/06/2010, 11:20
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 14 años, 10 meses
Puntos: 1517
Respuesta: Problema con sesiones

El ejemplo que haz indicado no veo algún error. Posiblemente el navegador que estés usando no tiene habilitado los cookies. para saber si no lo tienes habilitado haz esto
Código PHP:
Ver original
  1. <?php
  2. $_SESSION['foo'] = 'foo';
  3. echo SID;
Si sale la información en pantalla quiere decir que en ese navegador no está habilitado los cookies y son importantes para continuar las sesiones en cada página.
__________________
Verifica antes de preguntar.
Los verdaderos amigos se hieren con la verdad, para no perderlos con la mentira. - Eugenio Maria de Hostos
  #3 (permalink)  
Antiguo 21/06/2010, 11:29
 
Fecha de Ingreso: julio-2008
Mensajes: 62
Antigüedad: 15 años, 8 meses
Puntos: 0
Respuesta: Problema con sesiones

Cita:
Iniciado por abimaelrc Ver Mensaje
El ejemplo que haz indicado no veo algún error. Posiblemente el navegador que estés usando no tiene habilitado los cookies. para saber si no lo tienes habilitado haz esto
Código PHP:
Ver original
  1. <?php
  2. $_SESSION['foo'] = 'foo';
  3. echo SID;
Si sale la información en pantalla quiere decir que en ese navegador no está habilitado los cookies y son importantes para continuar las sesiones en cada página.
Hola, he probado y no sale nada.

¿Qué es el SID?
  #4 (permalink)  
Antiguo 21/06/2010, 11:32
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 14 años, 10 meses
Puntos: 1517
Respuesta: Problema con sesiones

Es una constante que se crea cuando no está habilitado las cookies. Pues un ejemplo entonces sencillo
a.php
Código PHP:
Ver original
  1. <?php
  2. $_SESSION['foo'] = 'foo';
  3. header('Location: b.php');
b.php
Código PHP:
Ver original
  1. <?php
  2. echo $_SESSION['foo'];
Déjanos saber que te sale en pantalla cuando ejecutas el archivo a.php.
__________________
Verifica antes de preguntar.
Los verdaderos amigos se hieren con la verdad, para no perderlos con la mentira. - Eugenio Maria de Hostos
  #5 (permalink)  
Antiguo 21/06/2010, 11:55
 
Fecha de Ingreso: julio-2008
Mensajes: 62
Antigüedad: 15 años, 8 meses
Puntos: 0
Respuesta: Problema con sesiones

Se dirige al b.php, y no imprime nada en pantalla.
  #6 (permalink)  
Antiguo 21/06/2010, 11:59
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 14 años, 10 meses
Puntos: 1517
Respuesta: Problema con sesiones

Haz esto a ver si te sale algo
a.php
Código PHP:
Ver original
  1. <?php
  2. $_SESSION['foo'] = 'foo';
  3. header('Location: b.php');
b.php
Código PHP:
Ver original
  1. <?php
  2. var_dump($_COOKIE);
__________________
Verifica antes de preguntar.
Los verdaderos amigos se hieren con la verdad, para no perderlos con la mentira. - Eugenio Maria de Hostos
  #7 (permalink)  
Antiguo 21/06/2010, 12:08
 
Fecha de Ingreso: julio-2008
Mensajes: 62
Antigüedad: 15 años, 8 meses
Puntos: 0
Respuesta: Problema con sesiones

Aquí ha salido esto:

array(1) { ["PHPSESSID"]=> string(26) "18d0k8sks25un70tt52i8dijb2" }
  #8 (permalink)  
Antiguo 21/06/2010, 13:11
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 14 años, 10 meses
Puntos: 1517
Respuesta: Problema con sesiones

Trata esto
a.php
Código PHP:
Ver original
  1. <?php
  2. $_SESSION['foo'] = 'foo';
  3. header('Location: b.php');
b.php
Código PHP:
Ver original
  1. <?php
  2. session_id($_COOKIE['PHPSESSID']);
  3. echo $_SESSION['foo'];
Si no te sale, vas a tener que verificar el php.ini y ver si tienes algo similar a esto (especialmente session.save_path)
Código INI:
Ver original
  1. [Session]
  2. session.save_handler = files
  3. session.save_path = "c:/php/tmp"
  4. session.use_cookies = 1
  5. ;session.cookie_secure =
  6. session.use_only_cookies = 1
  7. session.name = PHPSESSID
  8. session.auto_start = 0
  9. session.cookie_lifetime = 0
  10. session.cookie_path = /
  11. session.cookie_domain =
  12. session.cookie_httponly =
  13. session.serialize_handler = php
  14. session.gc_probability = 1
  15. session.gc_divisor = 1000
  16. session.gc_maxlifetime = 1440
  17. session.bug_compat_42 = On
  18. session.bug_compat_warn = On
  19. session.referer_check =
  20. session.entropy_length = 0
  21. session.entropy_file =
  22. ;session.entropy_length = 16
  23. session.cache_limiter = nocache
  24. session.cache_expire = 180
  25. session.use_trans_sid = 0
  26. session.hash_function = 0
  27. session.hash_bits_per_character = 5
El punto y coma antes de la directiva significa que está comentado y yo lo tengo indicado de esa forma, porque no las necesito. Esta directiva es basa en window, si es linux las rutas son de otra forma.
__________________
Verifica antes de preguntar.
Los verdaderos amigos se hieren con la verdad, para no perderlos con la mentira. - Eugenio Maria de Hostos
  #9 (permalink)  
Antiguo 21/06/2010, 13:22
 
Fecha de Ingreso: julio-2008
Mensajes: 62
Antigüedad: 15 años, 8 meses
Puntos: 0
Respuesta: Problema con sesiones

Ahora si que ha imprimido foo.
  #10 (permalink)  
Antiguo 21/06/2010, 13:24
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 14 años, 10 meses
Puntos: 1517
Respuesta: Problema con sesiones

Imprime como tienes el php.ini en la parte de session.
__________________
Verifica antes de preguntar.
Los verdaderos amigos se hieren con la verdad, para no perderlos con la mentira. - Eugenio Maria de Hostos
  #11 (permalink)  
Antiguo 21/06/2010, 13:49
 
Fecha de Ingreso: julio-2008
Mensajes: 62
Antigüedad: 15 años, 8 meses
Puntos: 0
Respuesta: Problema con sesiones

[Session]
; Handler used to store/retrieve data.
; http://php.net/session.save-handler
session.save_handler = files

; Argument passed to save_handler. In the case of files, this is the path
; where data files are stored. Note: Windows users have to change this
; variable in order to use PHP's session functions.
;
; The path can be defined as:
;
; session.save_path = "N;/path"
;
; where N is an integer. Instead of storing all the session files in
; /path, what this will do is use subdirectories N-levels deep, and
; store the session data in those directories. This is useful if you
; or your OS have problems with lots of files in one directory, and is
; a more efficient layout for servers that handle lots of sessions.
;
; NOTE 1: PHP will not create this directory structure automatically.
; You can use the script in the ext/session dir for that purpose.
; NOTE 2: See the section on garbage collection below if you choose to
; use subdirectories for session storage
;
; The file storage module creates files using mode 600 by default.
; You can change that by using
;
; session.save_path = "N;MODE;/path"
;
; where MODE is the octal representation of the mode. Note that this
; does not overwrite the process's umask.
; http://php.net/session.save-path
session.save_path = "C:\xampp\tmp"

; Whether to use cookies.
; http://php.net/session.use-cookies
session.use_cookies = 1

; http://php.net/session.cookie-secure
;session.cookie_secure =

; This option forces PHP to fetch and use a cookie for storing and maintaining
; the session id. We encourage this operation as it's very helpful in combatting
; session hijacking when not specifying and managing your own session id. It is
; not the end all be all of session hijacking defense, but it's a good start.
; http://php.net/session.use-only-cookies
session.use_only_cookies = 0

; Name of the session (used as cookie name).
; http://php.net/session.name
session.name = PHPSESSID

; Initialize session on request startup.
; http://php.net/session.auto-start
session.auto_start = 0

; Lifetime in seconds of cookie or, if 0, until browser is restarted.
; http://php.net/session.cookie-lifetime
session.cookie_lifetime = 0

; The path for which the cookie is valid.
; http://php.net/session.cookie-path
session.cookie_path = /

; The domain for which the cookie is valid.
; http://php.net/session.cookie-domain
session.cookie_domain =

; Whether or not to add the httpOnly flag to the cookie, which makes it inaccessible to browser scripting languages such as JavaScript.
; http://php.net/session.cookie-httponly
session.cookie_httponly =

; Handler used to serialize data. php is the standard serializer of PHP.
; http://php.net/session.serialize-handler
session.serialize_handler = php

; Defines the probability that the 'garbage collection' process is started
; on every session initialization. The probability is calculated by using
; gc_probability/gc_divisor. Where session.gc_probability is the numerator
; and gc_divisor is the denominator in the equation. Setting this value to 1
; when the session.gc_divisor value is 100 will give you approximately a 1% chance
; the gc will run on any give request.
; Default Value: 1
; Development Value: 1
; Production Value: 1
; http://php.net/session.gc-probability
session.gc_probability = 1

; Defines the probability that the 'garbage collection' process is started on every
; session initialization. The probability is calculated by using the following equation:
; gc_probability/gc_divisor. Where session.gc_probability is the numerator and
; session.gc_divisor is the denominator in the equation. Setting this value to 1
; when the session.gc_divisor value is 100 will give you approximately a 1% chance
; the gc will run on any give request. Increasing this value to 1000 will give you
; a 0.1% chance the gc will run on any give request. For high volume production servers,
; this is a more efficient approach.
; Default Value: 100
; Development Value: 1000
; Production Value: 1000
; http://php.net/session.gc-divisor
session.gc_divisor = 100

; After this number of seconds, stored data will be seen as 'garbage' and
; cleaned up by the garbage collection process.
; http://php.net/session.gc-maxlifetime
session.gc_maxlifetime = 1440

; NOTE: If you are using the subdirectory option for storing session files
; (see session.save_path above), then garbage collection does *not*
; happen automatically. You will need to do your own garbage
; collection through a shell script, cron entry, or some other method.
; For example, the following script would is the equivalent of
; setting session.gc_maxlifetime to 1440 (1440 seconds = 24 minutes):
; cd /path/to/sessions; find -cmin +24 | xargs rm

; PHP 4.2 and less have an undocumented feature/bug that allows you to
; to initialize a session variable in the global scope, even when register_globals
; is disabled. PHP 4.3 and later will warn you, if this feature is used.
; You can disable the feature and the warning separately. At this time,
; the warning is only displayed, if bug_compat_42 is enabled. This feature
; introduces some serious security problems if not handled correctly. It's
; recommended that you do not use this feature on production servers. But you
; should enable this on development servers and enable the warning as well. If you
; do not enable the feature on development servers, you won't be warned when it's
; used and debugging errors caused by this can be difficult to track down.
; Default Value: On
; Development Value: On
; Production Value: Off
; http://php.net/session.bug-compat-42
session.bug_compat_42 = On

; This setting controls whether or not you are warned by PHP when initializing a
; session value into the global space. session.bug_compat_42 must be enabled before
; these warnings can be issued by PHP. See the directive above for more information.
; Default Value: On
; Development Value: On
; Production Value: Off
; http://php.net/session.bug-compat-warn
session.bug_compat_warn = On

; Check HTTP Referer to invalidate externally stored URLs containing ids.
; HTTP_REFERER has to contain this substring for the session to be
; considered as valid.
; http://php.net/session.referer-check
session.referer_check =

; How many bytes to read from the file.
; http://php.net/session.entropy-length
session.entropy_length = 0

; Specified here to create the session id.
; http://php.net/session.entropy-file
;session.entropy_file = /dev/urandom
session.entropy_file =

; http://php.net/session.entropy-length
;session.entropy_length = 16

; Set to {nocache,private,public,} to determine HTTP caching aspects
; or leave this empty to avoid sending anti-caching headers.
; http://php.net/session.cache-limiter
session.cache_limiter = nocache

; Document expires after n minutes.
; http://php.net/session.cache-expire
session.cache_expire = 180

; trans sid support is disabled by default.
; Use of trans sid may risk your users security.
; Use this option with caution.
; - User may send URL contains active session ID
; to other person via. email/irc/etc.
; - URL that contains active session ID may be stored
; in publically accessible computer.
; - User may access your site with the same session ID
; always using URL stored in browser's history or bookmarks.
; http://php.net/session.use-trans-sid
session.use_trans_sid = 0

; Select a hash function for use in generating session ids.
; Possible Values
; 0 (MD5 128 bits)
; 1 (SHA-1 160 bits)
; http://php.net/session.hash-function
session.hash_function = 0

; Define how many bits are stored in each character when converting
; the binary hash data to something readable.
; Possible values:
; 4 (4 bits: 0-9, a-f)
; 5 (5 bits: 0-9, a-v)
; 6 (6 bits: 0-9, a-z, A-Z, "-", ",")
; Default Value: 4
; Development Value: 5
; Production Value: 5
; http://php.net/session.hash-bits-per-character
session.hash_bits_per_character = 5

; The URL rewriter will look for URLs in a defined set of HTML tags.
; form/fieldset are special; if you include them here, the rewriter will
; add a hidden <input> field with the info which is otherwise appended
; to URLs. If you want XHTML conformity, remove the form entry.
; Note that all valid entries require a "=", even if no value follows.
; Default Value: "a=href,area=href,frame=src,form=,fieldset="
; Development Value: "a=href,area=href,frame=src,input=src,form=fakeent ry"
; Production Value: "a=href,area=href,frame=src,input=src,form=fakeent ry"
; http://php.net/url-rewriter.tags
url_rewriter.tags = "a=href,area=href,frame=src,input=src,form=,fields et="
  #12 (permalink)  
Antiguo 21/06/2010, 14:05
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 14 años, 10 meses
Puntos: 1517
Respuesta: Problema con sesiones

Ufff, no podías quitar toda la información y dejar solo las directivas
Bueno con el trabajo que me costo leer toda la directiva y comparar lo que te recomiendo que modifiques esto
Código INI:
Ver original
  1. session.use_only_cookies = 1
Reinicia XAMPP y trata el código de esta forma
a.php
Código PHP:
Ver original
  1. <?php
  2. $_SESSION['foo'] = 'foo';
  3. header('Location: b.php');
b.php
Código PHP:
Ver original
  1. <?php
  2. echo $_SESSION['foo'];
__________________
Verifica antes de preguntar.
Los verdaderos amigos se hieren con la verdad, para no perderlos con la mentira. - Eugenio Maria de Hostos
  #13 (permalink)  
Antiguo 21/06/2010, 15:13
 
Fecha de Ingreso: julio-2008
Mensajes: 62
Antigüedad: 15 años, 8 meses
Puntos: 0
Respuesta: Problema con sesiones

Cita:
Iniciado por abimaelrc Ver Mensaje
Ufff, no podías quitar toda la información y dejar solo las directivas
Bueno con el trabajo que me costo leer toda la directiva y comparar lo que te recomiendo que modifiques esto
Código INI:
Ver original
  1. session.use_only_cookies = 1
Reinicia XAMPP y trata el código de esta forma
a.php
Código PHP:
Ver original
  1. <?php
  2. $_SESSION['foo'] = 'foo';
  3. header('Location: b.php');
b.php
Código PHP:
Ver original
  1. <?php
  2. echo $_SESSION['foo'];
Muchas gracias por las molestias que te has tomado....ahora ya funciona.

Un saludo.

Etiquetas: sesiones
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 17:23.