Ver Mensaje Individual
  #1 (permalink)  
Antiguo 06/06/2011, 12:44
follow
 
Fecha de Ingreso: marzo-2011
Mensajes: 88
Antigüedad: 13 años, 1 mes
Puntos: 17
Problema al insertar un dato en BD

Hola a todos, hace poco estuve preguntando por aquí la manera de hacer un registro de usuarios con tres tipos de usuarios diferentes, no sabía como enfocar el tema de las tablas y tal...

Ahora ya me he organizado y se lo que quiero, tengo el registro, que me mete al usuario en una tabla temporal y el usuario al activar la cuenta por via email se mete en otra tabla definitiva, en esa tabla almaceno los datos básicos que todos los usuarios (sean del tipo que sean) comparten Y UN CAMPO CON EL TIPO DE USUARIO.

El tema es que todo va bien pero no consigo ingresar en la BD el tipo de usuario, directamente no me introduce nada y al mismo tiempo no me salta ningún error... no se que puedo estar haciendo mal. Si alguien me puede revisar un poco el código lo agradecería... aunque sea un vistazo a ver si hay algo que yo no veo... y así ya de paso el que quiera usar el código pues perfecto! jejeje

Este es el tipico archivo de conexion y el de las funciones que utilizo:

Código PHP:
<?php

    $conn
;
    function 
conectar(){
        global 
$conn;
        
$conn mysql_connect("servidor","usuario","contraseña") or die (mysql_error());
        
mysql_select_db("usuario",$conn) or die (mysql_error());        
    }
    
    function 
desconectar() {
    
mysql_close($conn);
    }

?>
Código PHP:
<?php
require_once('class.phpmailer.php');
function 
mailActivacion($dir_correo$usuario$enlace){
    
$dominio "http://www.com/";
    
$mail = new PHPMailer();
    
$mail->IsSMTP();
    
$mail->SMTPAuth true;
    
$mail->SMTPSecure "tls";
    
$mail->Host       "smtp.gmail.com";
    
$mail->Port       587;
    
$mail->Username "usuario";
    
$mail->Password "Contraseña";
    
$body 
            <html> 
                <head> 
                   <title>Activar usuario</title> 
                </head> 
                <body> 
                    <h1>Hola'
;
    
$body .= $usuario;
    
$body .= '<p><b>Gracias por registrarte en</b>.</p>
            <p>Para completar el registro tienes que confirmar que has recibido el e-mail en el siguiente enlace:</p>
            <p style=text-align:center><a href='
;
    
$body .= $dominio $enlace;
    
$body .= " target=_blank>Activa tu usuario</a></p></body></html>";
    
$mail->SetFrom("[email protected]");
    
$mail->AddAddress($dir_correo,$usuario);
    
$mail->Subject "registro asdfasdf";
    
$mail->MsgHTML($body);
    
$mail->Send();
}

function 
generar_txtAct($longitud,$especiales){ 
                
// Array con los valores a escojer
        
$semilla = array(); 
        
$semilla[] = array('a','e','i','o','u');  
        
$semilla[] = array('b','c','d','f','g','h','j','k','l','m','n','p','q','r','s','t','v','w','x','y','z'); 
        
$semilla[] = array('0','1','2','3','4','5','6','7','8','9'); 
        
$semilla[] = array('A','E','I','O','U');  
        
$semilla[] = array('B','C','D','F','G','H','J','K','L','M','N','P','Q','R','S','T','V','W','X','Y','Z'); 
        
$semilla[] = array('0','1','2','3','4','5','6','7','8','9'); 
         
        
// si puede contener caracteres especiales, aumentamos el array $semilla 
        
if ($especiales) { $semilla[] = array('$','#','%','&','@','-','?','¿','!','¡','+','-','*'); } 
         
        
// creamos la clave con la longitud indicada 
                
for ($bucle=0$bucle $longitud$bucle++)  
                { 
                    
// seleccionamos un subarray al azar 
                    
$valor mt_rand(0count($semilla)-1); 
                    
// selecccionamos una posicion al azar dentro del subarray 
                    
$posicion mt_rand(0,count($semilla[$valor])-1); 
                    
// cojemos el caracter y lo agregamos a la clave 
                    
$clave .= $semilla[$valor][$posicion]; 
                    } 
                    
// devolvemos la clave 
                    
return $clave
}

//FUNCION PARA INSERTAR EL REGISTRO EN LA TABLA users_temp
function insertarReg($name_$username_$password1_$email_$tipo_usuario_){
    
        
//Declaramos esta variable global, para poder usarla en toda la aplicación
        
global $url;
        
//LLamar a la función para generar el texto aleatorio para Activar Usuario.
        //Le pasamos como parámetro los caracteres que queremos generar y si los queremos especiales o no
        
$clave generar_txtAct(20,false);
        
//Montamos la estructura del enlace con la clave.
        
$url "activar.php?id=" $clave;
        
        
        
/*Teneis que declarar las variables $servidor, $usuario,$password y 
          $sdb (base de datos). En mi caso para Localhost tengo lo siguiente:*/
        
$servidor "servidor";
        
$usuario "usuario";
        
$password "contrasena";
        
$sdb "basedatos";
                
        
$ilink3=mysql_connect($servidor,$usuario,$password) or die(mysql_error()); 
        
mysql_select_db($sdb,$ilink3); 
        
        
$inserta"insert into users_temp (usersTemp,password,email,fecAlta,txt_Activ,tipo_usuario) values ('$username_','$password1_','$email_',CURDATE(),'$clave','$tipo_usuario_')";
        
$resultado3=mysql_query($inserta,$ilink3) or die (mysql_error());
        
        if (!
$resultado3)
        return 
false;
        else
            return 
true;
}

/*function validateName($name){
    //NO cumple longitud minima
    if(strlen($name) < 5)
        return false;
    //SI longitud pero NO solo caracteres A-z
    else if(!preg_match("/^[a-zA-Z]+$/", $name))
        return false;
    // SI longitud, SI caracteres A-z
    else
        return true;
}*/

function validateName($name){
$permitidos "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_";
    
$caracter1KO 0;
    if(
strlen($name) < 5):
        return 
false;
    else:
    for (
$i=0$i<strlen($name); $i++){ 
          if (
strpos($permitidossubstr($name,$i,1))===false){ 
             
$caracter1KO 1;
                 } 
    }
    endif;
    if (
$caracter1KO == || strlen($name) <= 4):
        return 
false;
    else:
        return 
true;
    endif;
}

function 
validateUsername($username){
    
$permitidos "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_";
    
$caracterKO 0;
    if(
strlen($username) < 5):
        return 
false;
    else:
    for (
$i=0$i<strlen($username); $i++){ 
          if (
strpos($permitidossubstr($username,$i,1))===false){ 
             
$caracterKO 1;
                 } 
    }
    endif;
    if (
$caracterKO == || strlen($username) <= 4):
        return 
false;
    else:
        return 
true;
    endif;
}


function 
validateExistUsername($username){
        
/*Teneis que declarar las variables $servidor, $usuario,$password y 
          $sdb (base de datos). En mi caso para Localhost tengo lo siguiente:*/
            
$servidor "servidor";
        
$usuario "usuario";
        
$password "contrasena";
        
$sdb "basedatos";
        
        
$ilink=mysql_connect($servidor,$usuario,$password) or die(mysql_error()); 

        
mysql_select_db($sdb,$ilink); 
        
$consulta"select usersTemp from users_temp where usersTemp = '$username'";
        
$resultado=mysql_query($consulta,$ilink) or die (mysql_error());
        if (
mysql_num_rows($resultado)>0)
            return 
false;
        else
            return 
true;
}

function 
validatePassword1($password1){
    
//NO tiene minimo de 5 caracteres o mas de 12 caracteres
    
if(strlen($password1) < || strlen($password1) > 12)
        return 
false;
    
// SI longitud, NO VALIDO numeros y letras
    
else if(!preg_match("/^[0-9a-zA-Z]+$/"$password1))
        return 
false;
    
// SI rellenado, SI email valido
    
else
        return 
true;
}

function 
validatePassword2($password1$password2){
    
//NO coinciden
    
if($password1 != $password2)
        return 
false;
    else
        return 
true;
}

function 
validateEmail($email){
    
if ((
strlen($email) >= 6) && (substr_count($email,"@") == 1) && (substr($email,0,1) != "@") && (substr($email,strlen($email)-1,1) != "@")){ 
           if ((!
strstr($email,"'")) && (!strstr($email,"\"")) && (!strstr($email,"\\")) && (!strstr($email,"\$")) && (!strstr($email," "))) { 
              
//miro si tiene caracter . 
              
if (substr_count($email,".")>= 1){ 
                 
//obtengo la terminacion del dominio 
                 
$term_dom substr(strrchr ($email'.'),1); 
                 
//compruebo que la terminación del dominio sea correcta 
                 
if (strlen($term_dom)>&& strlen($term_dom)<&& (!strstr($term_dom,"@")) ){ 
                    
//compruebo que lo de antes del dominio sea correcto 
                    
$antes_dom substr($email,0,strlen($email) - strlen($term_dom) - 1); 
                    
$caracter_ult substr($antes_dom,strlen($antes_dom)-1,1); 
                    if (
$caracter_ult != "@" && $caracter_ult != "."){ 
                       
$mail_correcto 1
                    } 
                 } 
              } 
           } 
       } 
       if (
$mail_correcto
           return 
true
       else 
           return 
false


function 
validateExistMail($mail){
        
/*Teneis que declarar las variables $servidor, $usuario,$password y 
          $sdb (base de datos). En mi caso para Localhost tengo lo siguiente:*/
            
$servidor "servidor";
        
$usuario "usuario";
        
$password "contrasena";
        
$sdb "basedatos";
        
        
$ilink2=mysql_connect($servidor,$usuario,$password) or die(mysql_error()); 
        
mysql_select_db($sdb,$ilink2); 
        
$consulta2"select id_usersTemp from users_temp where email = '$mail'";
        
$resultado2=mysql_query($consulta2,$ilink2) or die (mysql_error());
        if (
mysql_num_rows($resultado2)>0)
            return 
false;
        else
            return 
true;
}

?>