A estas alturas ya tenemos instalado nuestro
CMS y preparada la mecánica de nuestro entorno modular, ademas en la instalación definimos un único usuario, que hará de administrador, pero
¿que hacemos si queremos permitir registrar mas usuarios? Pues haremos un sistema de registro :P .
Anteriormente creamos una script en
includes/ llamada
register.php, nos dirigimos a ella y empezamos a preparar nuestro sistema de registro.
La script
register.php va a tener dos partes, una de ellas es el formulario de registro en xhtml y la otra parte servirá para procesar el envío, para esto usaremos
if().
Yo estoy a favor de usar todas las script que necesite de forma que las llames cuando te hagan falta siempre dentro de un limite, pero en este caso crear dos archivos separados para un registro no lo veo realmente útil.
Dentro de
register.php y
siempre debajo de
comenzamos nuestro script,
siempre debajo porque lo primero que se debe de comprobar es que la constante esta definida para evitar problemas de seguridad.
Añadimos un
if() muy simple que controle el valor ‘
submit‘ que entra por
_POST, si
$_POST['submit'] existe procesamos el envío, si no es así presentamos el formulario de registro, seria algo así:
Código PHP:
Ver originalif(isset($_POST['submit'])){
//Ahora procesamos el envio
}else{
//Mostramos el formulario
}
Ahora dentro del
if() en la primera parte que es la que se muestra si se envió el formulario añadimos diferentes parámetros que usaremos de requisitos para el registro, yo lo usare para controlar el máximo y el mínimo de caracteres del usuario y contraseña, pero hay muchas mas posibilidades dependiendo de lo que quieras controlar, también habría que comprobar si el email es valido mediante expresiones regulares, pero por el momento lo dejamos así.
Código PHP:
Ver original$user_min_len = 4;
$user_max_len = 32;
$pass_min_len = 6;
$pass_max_len = 32;
Una vez definidas las variables pasamos a comprobar que al enviar el formulario se rellenaron todos los campos y que ademas de estar rellenos cumplen con nuestros requisitos, para eso usaremos las funciones
empty() y la función
strlen() la cual cuenta el numero de caracteres, y en caso de no cumplir lo que buscamos definimos la variable
$return = 1. Algo así:
Código PHP:
Ver original//Comprobamos que el campo usuario no este vacio.
if(!empty($_POST['user_name'])){
//Comprobamos que cumplan los requisitos que definimos
if((strlen($_POST['user_name']) < $user_min_len)||(strlen($_POST['user_name']) > $user_max_len)){ echo "El usuario no puede ser menor de ".$user_min_len." ni mayor de ".$user_max_len." letras. <br />";
$return = 1;
}
}else{
//En caso de que este vacío
echo "Tienes que rellenar el campo de usuario <br />";
$return = 1;
}
Debemos de hacer igual pero para el campo password, que sera el que almacene la contraseña, y para el campo email, pero en el caso del correo electrónico solamente comprobaremos que no esta vacío.
Lo siguiente sera comprobar que el nombre de usuario no este ya registrado, asi evitamos errores con la base de datos, para ello hacemos una consulta a la base de datos de la siguiente forma:
Código PHP:
Ver original//Comprobamos en la base de datos que no existe ya el usuario
$sql = mysql_query("SELECT * FROM users WHERE user='".$_POST['user_name']."'"); {
echo "El usuario ya existe <br />";
$return = 1;
}
La ultima comprobación que hacemos aquí es si la variable
$return fue definida, puesto que si se definió significa que hubo alguna incidencia, si no la hubo registramos al usuario, pasamos por
md5() la contraseña y terminamos con el procesos del formulario.
Código PHP:
Ver original//Nos aseguramos de que la variable return no se haya definido para poder continuar
echo "<br /><a href=\"index.php?sec=registro\">Volver al Formulario</a>";
}else{
//Introducimos los datos del nuevo usuario en la base de datos
mysql_query("INSERT INTO users (user, pass, email, date, status) values ('".$_POST['user_name']."','".$_POST['password']."','".$_POST['email']."','".time()."','1')")or
die(mysql_error()); echo "Usuario registrado correctamente";
echo "<br /><a href=\"index.php\">Volver al Indice</a>";
}
Ya podemos olvidarnos de esta parte del script, ahora nos centramos en el formulario, el cual ha de ser muy simple, solamente pedimos usuarios, contraseña y email, y enviamos el resultado a
index.php?sec=registro, este podría ser el resultado final de nuestro script de registro:
register.php:
Código PHP:
Ver original<?php
//Si el script se ejecuta de forma separada a index.php redireccionamos al index.
header('Location: index.php'); }
//Comprobamos que se envió el fomulario
if(isset($_POST['submit'])){
//Definimos requisitos de maximo y minimo de usuario y contraseña
$user_min_len = 4;
$user_max_len = 32;
$pass_min_len = 6;
$pass_max_len = 32;
//Comprobamos que el campo usuario no este vacio.
if(!empty($_POST['user_name'])){
//Comprobamos que cumplan los requisitos que definimos
if((strlen($_POST['user_name']) < $user_min_len)||(strlen($_POST['user_name']) > $user_max_len)){ echo "El usuario no puede ser menor de ".$user_min_len." ni mayor de ".$user_max_len." letras. <br />";
$return = 1;
}
}else{
//En caso de que este vacio
echo "Tienes que rellenar el campo de usuario <br />";
$return = 1;
}
//Comprobamos que el campo contraseña no este vacio
if(!empty($_POST['password'])){
//Comprobamos que cumplan los requisitos que definimos
if((strlen($_POST['password']) < $pass_min_len)||(strlen($_POST['password']) > $pass_max_len)){ echo "La Contraseña no puede ser menor de ".$user_min_len." ni mayor de ".$user_max_len." letras. <br />";
$return = 1;
}
}else{
//En caso de que este vacio
echo "Tienes que rellenar el campo de Constraseña <br />";
$return = 1;
}
//Comprobamos que el campo email este vacio
if(empty($_POST['email'])){
//En caso de que este vacio
echo "Tienes que rellenar el campo de Email <br />";
$return = 1;
}
//Comprobamos en la base de datos que no existe ya el usuario
$sql = mysql_query("SELECT * FROM users WHERE user='".$_POST['user_name']."'"); {
echo "El usuario ya existe <br />";
$return = 1;
}
//Nos aseguramos de que la variable return no se haya definido para poder continuar
echo "<br /><a href=\"index.php?sec=registro\">Volver al Formulario</a>";
}else{
//Introducimos los datos del nuevo usuario en la base de datos
mysql_query("INSERT INTO users (user, pass, email, date, status) values ('".$_POST['user_name']."','".$_POST['password']."','".$_POST['email']."','".time()."','1')")or
die(mysql_error()); echo "Usuario registrado correctamente";
echo "<br /><a href=\"index.php\">Volver al Indice</a>";
}
}else{ //Mostramos el formulario de envio
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<link type="text/css" rel="stylesheet" media="all" href="style.css" />
<title>Registrar nuevo Usuario</title>
</head>
<body>
<div id="install">
<form action="index.php?sec=registro" method="post">
<div id="install-title">Registro de Nuevos Usuarios</div>
<table>
<tr><td colspan="2" class="install-td">Datos del Usuario</td></tr>
<tr><td>Nombre de Usuario:</td><td><input type="text" name="user_name" value="Usuario" /></td></tr>
<tr><td>Contraseña:</td><td><input type="text" name="password" value="Contraseña" /></td></tr>
<tr><td>Correo Electrónico:</td><td><input type="text" name="email" value="Email" /></td></tr>
<tr><td colspan="2" class="install-td"><input type="submit" name="submit" value="Registrar" /></td></tr>
</table>
</form>
</div>
</body>
</html>
<?
}
?>
Ahora que tenemos como registrar usuarios, necesitaremos donde hacer ‘
Login‘ y ‘
Logout‘ del sistema, pero eso lo explicare en otra entrada. Podéis bajar todos los script hasta el momento
aquí.
Dudas, comentarios, criticas, sugerencias, etc… serán agradecidas!
Un Saludo.