1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" >
<head>
<title>Inscription</title>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
<link rel="stylesheet" media="screen" type="text/css" title="Design" href="design.css" />
</head>
<body>
<div id="en_tete">
<!-- Ici on mettra la bannière -->
</div>
<div id="menu">
<div class="element_menu">
<?php // Enregistrons les informations de date dans des variables
$jour = date('d');
$mois = date('m');
$annee = date('Y');
$heure = date('H');
$minute = date('i'); // Maintenant on peut afficher ce qu'on a recueilli
echo 'Bonjour ! Nous sommes le ' . $jour . '/' . $mois . '/' . $annee . 'et il est ' . $heure. ' h ' . $minute;
?>
</div>
<div class="element_menu">
<h3></h3>
<ul>
<li><a href="index.php">Accueil</a></li>
<li><a href="conn.php">Connexion</a></li>
<li></li>
</ul>
</div>
</div>
<div id="corps">
<?php
if(isset($_POST["BT_Envoyer"]))
{
// Vérification de la validité des champs
if(!ereg("^[A-Za-z0-9_]{4,20}$", $_POST["TB_pseudo"]))
{
$message = "Votre pseudo doit comporter entre 4 et 20 caractères<br />\n";
$message .= "L'utilisation de l'underscore est autorisée";
}
elseif(!ereg("^[A-Za-z0-9]{4,}$", $_POST["TB_MP"]))
{
$message = "Votre mot de passe doit comporter au moins 4 caractères";
}
elseif($_POST["TB_MP"] != $_POST["TB_Confirm_MP"])
{
$message = "Votre mot de passe n'a pas été correctement confirmé";
}
elseif(!ereg("^[a-zA-Z0-9._-]+@[a-zA-Z0-9.-]{2,}[.][a-zA-Z]{2,4}$",
$_POST["TB_E_mail"]))
{
$message = "Votre adresse e-mail n'est pas valide";
}
else
{
// Connexion à la base de données
// Valeurs à modifier selon vos paramètres configuration
mysql_connect("localhost", "root", "");
mysql_select_db("siteaimemoi");
// Vérification de l'unicité du nom d'utilisateur et de l'adresse e-mail
$result = mysql_query("
SELECT pseudo
, E_mail
FROM membres
WHERE pseudo = '" . $_POST["TB_pseudo"] . "'
OR E_mail = '" . $_POST["TB_E_mail"] . "'
");
// Si une erreur survient
if(!$result)
{
$message = "Erreur d'accès à la base de données lors de la vérification d'unicité";
}
else
{
// Si un enregistrement est trouvé
if(mysql_num_rows($result) > 0)
{
while($row = mysql_fetch_array($result))
{
if($_POST["TB_pseudo"] == $row["pseudo"])
{
$message = "Le pseudo" . $_POST["TB_pseudo"];
$message .= "est déjà utilisé";
}
elseif($_POST["TB_E_mail"] == $row["E_mail"])
{
$message = "L'adresse e-mail " . $_POST["TB_E_mail"];
$message .= "est déjà utilisée";
}
}
}
else
{
// Génération de la clef d'activation
$caracteres = array("a", "b", "c", "d", "e", "f", 0, 1, 2, 3, 4, 5, 6, 7, 8, 9);
$caracteres_aleatoires = array_rand($caracteres, 8);
$clef = "";
foreach($caracteres_aleatoires as $i)
{
$clef .= $caracteres[$i];
}
// Création du compte utilisateur
$result = mysql_query("
INSERT INTO membres(
pseudo
, MP
, E_mail
, Date_Inscri
, clef
)
VALUES(
'" . $_POST["TB_pseudo"] . "'
, '" . md5($_POST["TB_MP"]) . "'
, '" . $_POST["TB_E_mail"] . "'
, '" . time() . "'
, '" . $clef . "'
)
");
// Si une erreur survient
if(!$result)
{
$message = "Erreur d'accès à la base de données lors de la création du compte";
}
else
{
// Envoi du mail d'activation
$sujet = "Activation de votre compte";
$message = "Pour valider votre inscription, merci de cliquer sur le lien suivant :\n";
$message .= "http://" . $_SERVER["SERVER_NAME"];
$message .= "/activer-compte-utilisateur.php?id=" . mysql_insert_id();
$message .= "&clef=" . $clef;
// Si une erreur survient
if(!@mail($_POST["TB_E_mail"], $sujet, $message))
{
$message = "Une erreur est survenue lors de l'envoi du mail d'activation<br />\n";
$message .= "Veuillez contacter l'administrateur afin d'activer votre compte";
}
else
{
// Message de confirmation
$message = "Votre compte a correctement été créer<br />\n";
$message .= "Un email vient de vous être envoyer afin de l'activer";
// On masque le formulaire
$masquer_formulaire = true;
}
}
}
}
}
// Fermeture de la connexion à la base de données
mysql_close();
}
?>
<DIV ALIGN="CENTER"><H2>devenez membre</H2></DIV>
<form action="http://<?php echo $_SERVER["SERVER_NAME"] . $_SERVER["SCRIPT_NAME"]; ?>" method="post">
<fieldset>
<legend>Inscription</legend>
<p>
<label for="pseudo">Votre pseudo</label><input type="text" name="TB_pseudo" id="pseudo"/>
</p>
<p>
<label for="MP">Votre mot de passe</label><input type="password" name="TB_MP" id="MP"/>
</p>
<p>
<label for="Confirm_MP">Confirmation du mot de passe</label><input type="password" name="TB_Confirm_MP" id="Confirm_MP"/>
</p>
<p>
<label for="E_mail">Votre adresse E_mail</label><input type="text" name="TB_E_mail" id="E_mail"/>
</p>
<p>
<label for="Envoyer"><input type="submit" name="BT_Envoyer" value="Envoyer"/></label><label for="effacer"><input type="submit" name="BT_effacer" value="effacer"/>
</fieldset>
</form>
</div>
<div id="pied_de_page">
<!-- Enfin, on mettra en bas de la page le nom de l'auteur, un copyright... -->
</div>
</body>
</html> |