Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] Utilizar una sesion para realizar un insert

Estas en el tema de Utilizar una sesion para realizar un insert en el foro de PHP en Foros del Web. Estoy realizando un formulario con usuarios previamente registrados, y quiero utilizar la sesion para poder hacer los insert correctamente. Os explico un poco mejor, tengo ...
  #1 (permalink)  
Antiguo 20/04/2013, 09:53
 
Fecha de Ingreso: abril-2013
Ubicación: Barcelona
Mensajes: 23
Antigüedad: 11 años, 7 meses
Puntos: 0
Pregunta Utilizar una sesion para realizar un insert

Estoy realizando un formulario con usuarios previamente registrados, y quiero utilizar la sesion para poder hacer los insert correctamente. Os explico un poco mejor, tengo una tabla de usuarios con sólo 3 campos, id, nombre y password.

Cuando un usuario entra, compruebo si existe el user y el pass es correcto, y creo una sesión.. os pongo el codigo:

Código:
if(isset($_POST['submit'])){ 
    $usr = mysql_real_escape_string($_POST['usuario']); 
    $pas = hash('md5', mysql_real_escape_string($_POST['password'])); 
    $sql = mysql_query("SELECT * FROM usuarios  
        WHERE usuario='$usr' AND 
        password='$pas' 
        LIMIT 1"); 
    if(mysql_num_rows($sql) == 1){ 
        $row = mysql_fetch_array($sql); 
        session_start(); 	
	$_SESSION['id'] = $row['id'];
        $_SESSION['usuario'] = $row['usuario'];  
        $_SESSION['logged'] = TRUE; 
        header("Location: instrucciones.php");
...
Bien, el caso es que creo otra tabla con tres campos, id, provincia y poblacion, el id, debería corresponder al id del usuario, por eso lo quiero incluir en la sesion para despues realizar el insert, pero al parecer, no lo hago bien o no se puede hacer...

En otro archivo necesito insertar los registros que recojo de otro formulario y asignarlos al id del usuario logeado:

Código:
if($_SESSION['logged']==TRUE){ 

 $query = sprintf("INSERT INTO sectionA(`id`,`a1`,`a2`)
            VALUES('%s','%s','%s')", 
            mysql_real_escape_string($_SESSION['id']), 
			mysql_real_escape_string($_POST['provincia']),
            mysql_real_escape_string($_POST['poblacion']))or die(mysql_error());
        $sql = mysql_query($query);
Si compruebo la variable de la sesion del usuario, funciona bien, es decir, me muestra el nombre del usuario que se ha logeado, pero si quiero mostrar el id del usuario logeado que corresponde a la BD no hay manera.

Disculpar si la pregunta es de muy novata, pero por más que leo no acabo de aclararme.

Muchas gracias
  #2 (permalink)  
Antiguo 20/04/2013, 11:27
Avatar de Triby
Mod on free time
 
Fecha de Ingreso: agosto-2008
Ubicación: $MX->Gto['León'];
Mensajes: 10.106
Antigüedad: 16 años, 3 meses
Puntos: 2237
Respuesta: Utilizar una sesion para realizar un insert

Para que PHP pueda manejar correctamente las sesiones, siempre debes tener session_start(); sin importar el control interno que hagas para validar usuarios o invitados.

Para ver lo que tienes en sesión usa var_dump($_SESSION);
__________________
- León, Guanajuato
- GV-Foto
  #3 (permalink)  
Antiguo 21/04/2013, 00:59
 
Fecha de Ingreso: abril-2013
Ubicación: Barcelona
Mensajes: 23
Antigüedad: 11 años, 7 meses
Puntos: 0
[SOLUCIONADO] Utilizar una sesion para realizar un insert

Gracias Triby, no podia ser más simple...

Etiquetas: sesiones_en_php
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:42.