Modifica la tabla creando el campo AVATAR
Código SQL:
Ver originalCREATE TABLE `users` (
`id` INT( 4 ) NOT NULL AUTO_INCREMENT,
`nick` VARCHAR(30) NOT NULL ,
`pass` VARCHAR(30) NOT NULL ,
`email` VARCHAR(50) NOT NULL ,
`avatar` VARCHAR(90) NOT NULL,
`fecha` INT(15) NOT NULL ,
`level` INT(2) NOT NULL ,
`rollo` LONGTEXT NOT NULL ,
INDEX ( `id` )
);
Modifica el registro agregando el campo VATAR para que inserten la URL.
Reg.php
Código PHP:
Ver original<?
include('config.php'); //incluimos el config.php que contiene los datos de la conexión a la db
//Creamos el form k irá a registrar.php para comprobar y introducir los datos a la tabla users
echo '<form action="registrar.php" method="POST">
Nick: <input type="text" name="nick" size="30"><br>
Password: <input type="password" name="pass" size="30" ><br>
Repetir Password: <input type="password" name="pass1" size="30" ><br>
email: <input type="text" name="email" size="50"><br>
Rollo: <textarea name="rollo" cols="30" rows="10"></textarea><br>
Avatar URL: <input type="text" name="avatar" size="90"><br>
<input type="submit" name="submit" value="Enviar"></form>';
?>
Y cambiamos el registro:
Registrar.php
Código PHP:
Ver original<?
include('config.php'); //incluimos el config.php que contiene los datos de la conexión a la db
//Comprobamos que los campos nick, pass y pass1 se han rellenado en el form de reg.php, sino volvemos al form
if(($_POST[nick] == ' ') or ($_POST[pass] == ' ') or ($_POST[pass1] == ' ') )
{
Header("Location: reg.php"); //enviamos al form de registro que esta en reg.php }else{
//Comprobamos que la pass y pass1 son iguales, sino, volvemos a reg.php
if($_POST[pass] != $_POST[pass1])
{
echo 'Las passwords no son iguales';
}else{
//quitamos el codigo malicioso de $_POST[nick] y $_POST[pass]
//comprobamos que el usuario no existe en la db
$usuarios=mysql_query("SELECT nick FROM users WHERE nick='$user' "); {
echo 'El usuario ya esta registrado';
}else{
//quitamos todo el codigo malicioso de las demas variables del form de registro
$rollo = str_replace("\n\r","<br>",$rollo); //se cambian los saltos de linea por <br>
$avatar = str_replace("\n\r","",$avatar ); //se cambian los saltos de linea por NADA
$level = "2"; //usaremos level 1 para admins, level 2 para los demas (se cambia manualmente desde phpmyadmin)
//introducimos el nuevo registro en la tabla users
mysql_query("INSERT INTO users (avatar,nick,pass,email,fecha,level,rollo) values ('$avatar','$user','$pass','$email','$fecha','$level','$roll o') "); echo 'Usuario registrado con éxito';
}
}
}
?>
Autentificar.php
Código PHP:
Ver original<?
include('config.php'); //incluimos el config.php que contiene los datos de la conexión a la db
if( ($_POST[nick] == ' ') or ($_POST[pass] == ' ') )//comprobamos que las variables enviadas por el form de login.php tienen contenido
{
Header("Location: login.php"); //estan vacías, volvemos al index }else{
//comprobamos en la db si existe ese nick con esa pass
$usuarios=mysql_query("SELECT * FROM users WHERE nick='$_POST[nick]' and pass='$_POST[pass]' "); if($user_ok = mysql_fetch_array($usuarios)) //si existe comenzamos con la sesion, si no, al index {
session_register("usuario"); //registramos la variable usuario que contendrá el nick del user session_register("idusuario"); //registramos la variable idusuario que contendrá la id del user session_register("level"); //registramos la variable level que contendrá el level del user //damos valores a las variables de la sesión
$_SESSION[avatar] = $user_ok["avatar"];//Recojemos el dato avatar
$_SESSION[usuario] = $user_ok["nick"]; //damos el nick a la variable usuario
$_SESSION[idusuario] = $user_ok["id"]; //damos la id del user a la variable idusuario
$_SESSION[level] = $user_ok["level"]; //damos el level del user a la variable level
Header("Location: login.php"); //volvemos al login donde nos saldrá nuestro menú de usuario
}else{
echo 'Nick y pass incorrectos';
}
}
?>
Y para mostrar el AVATAR solamente pones
<img src="<?=$_SESSION[avatar]?>" alt="avatar no existe" />
Espero que sirva