Historisation Exemple
Exemple test historisé
This commit is contained in:
45
inscription/Note.txt
Normal file
45
inscription/Note.txt
Normal file
@@ -0,0 +1,45 @@
|
||||
- Mettre Msg erreur dans une function
|
||||
|
||||
<?php
|
||||
exit('<div id="error"><p>'.$mess.'</p>
|
||||
<p>Cliquez <a href="./index.php">ici</a> pour revenir à la page d\'accueil</p></div></div></body></html>');
|
||||
?>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
Connexion
|
||||
|
||||
--Cacher si pas connecter
|
||||
<input type="hidden" name="page" value="<?php echo $_SERVER['HTTP_REFERER']; ?>" />
|
||||
|
||||
--Session Membre ou non
|
||||
<?php
|
||||
$page = htmlspecialchars($_POST['page']);
|
||||
echo 'Cliquez <a href="'.$page.'">ici</a> pour revenir à la page précédente';
|
||||
?>
|
||||
|
||||
Inscrription mail (function.php)
|
||||
|
||||
<?php
|
||||
//Message
|
||||
$message = "Bienvenue sur mon super forum !";
|
||||
//Titre
|
||||
$titre = "Inscription à mon super forum !";
|
||||
|
||||
mail($_POST['adressemail'], $titre, $message);
|
||||
?>
|
||||
|
||||
|
||||
Amelioration possible
|
||||
|
||||
- Validation avec code aléatoire : inscription
|
||||
|
||||
- check Box se souvenir de moi connexion
|
||||
|
||||
- Systeme Anti Bot
|
||||
|
||||
|
||||
|
||||
-- Cryptage en md5
|
||||
87
inscription/connexion.php
Normal file
87
inscription/connexion.php
Normal file
@@ -0,0 +1,87 @@
|
||||
<?php
|
||||
session_start();
|
||||
$titre="Connexion";
|
||||
include("includes/identifiants.php");
|
||||
include("includes/debut.php");
|
||||
include("includes/menu.php");
|
||||
echo '<p><i>Vous êtes ici</i> : <a href="./index.php">Index du forum</a> --> Connexion';
|
||||
?>
|
||||
|
||||
|
||||
<?php
|
||||
echo '<h1>Connexion</h1>';
|
||||
if ($id!=0) erreur(ERR_IS_CO);
|
||||
?>
|
||||
|
||||
<?php
|
||||
if (!isset($_POST['pseudo'])) //On est dans la page de formulaire
|
||||
{
|
||||
echo '<form method="post" action="connexion.php">
|
||||
<fieldset>
|
||||
<legend>Connexion</legend>
|
||||
<p>
|
||||
<label for="pseudo">Pseudo :</label><input name="pseudo" type="text" id="pseudo" /><br />
|
||||
<label for="password">Mot de Passe :</label><input type="password" name="password" id="password" />
|
||||
</p>
|
||||
</fieldset>
|
||||
<p><input type="submit" value="Connexion" /></p></form>
|
||||
<a href="./register.php">Pas encore inscrit ?</a>
|
||||
|
||||
</div>
|
||||
</body>
|
||||
</html>';
|
||||
}
|
||||
|
||||
//On reprend la suite du code
|
||||
else
|
||||
{
|
||||
$message='';
|
||||
if (empty($_POST['pseudo']) || empty($_POST['password']) ) //Oublie d'un champ
|
||||
{
|
||||
$message = '<p>une erreur s\'est produite pendant votre identification.
|
||||
Vous devez remplir tous les champs</p>
|
||||
<p>Cliquez <a href="./connexion.php">ici</a> pour revenir</p>';
|
||||
}
|
||||
else //On check le mot de passe
|
||||
{
|
||||
$query=$db->prepare('SELECT membre_mdp, membre_id, membre_rang, membre_pseudo
|
||||
FROM forum_membres WHERE membre_pseudo = :pseudo');
|
||||
$query->bindValue(':pseudo',$_POST['pseudo'], PDO::PARAM_STR);
|
||||
$query->execute();
|
||||
$data=$query->fetch();
|
||||
if ($data['membre_mdp'] == md5($_POST['password'])) // Acces OK !
|
||||
{
|
||||
$_SESSION['pseudo'] = $data['membre_pseudo'];
|
||||
$_SESSION['level'] = $data['membre_rang'];
|
||||
$_SESSION['id'] = $data['membre_id'];
|
||||
$message = '<p>Bienvenue '.$data['membre_pseudo'].',
|
||||
vous êtes maintenant connecté!</p>
|
||||
<p>Cliquez <a href="./index.php">ici</a>
|
||||
pour revenir à la page d accueil</p>';
|
||||
}
|
||||
else // Acces pas OK !
|
||||
{
|
||||
$message = '<p>Une erreur s\'est produite
|
||||
pendant votre identification.<br /> Le mot de passe ou le pseudo
|
||||
entré n\'est pas correcte.</p><p>Cliquez <a href="./connexion.php">ici</a>
|
||||
pour revenir à la page précédente
|
||||
<br /><br />Cliquez <a href="./index.php">ici</a>
|
||||
pour revenir à la page d accueil</p>';
|
||||
}
|
||||
$query->CloseCursor();
|
||||
}
|
||||
echo $message.'</div></body></html>';
|
||||
|
||||
}
|
||||
?>
|
||||
|
||||
<input type="hidden" name="page" value="<?php echo $_SERVER['HTTP_REFERER']; ?>" />
|
||||
<?php
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
50
inscription/css/design.css
Normal file
50
inscription/css/design.css
Normal file
@@ -0,0 +1,50 @@
|
||||
#banniere
|
||||
{
|
||||
width: 600px;
|
||||
height: 150px;
|
||||
background-position: center;
|
||||
margin-bottom: 20px;
|
||||
background-image: url('images/banniere.jpg');
|
||||
}
|
||||
|
||||
#corps_forum
|
||||
{
|
||||
border: 1px solid black;
|
||||
width: 90%;
|
||||
margin-top: 50px;
|
||||
margin-left: 5%;
|
||||
margin-bottom: 10Opx;
|
||||
padding: 5px;
|
||||
background-color: rgb(237,224,213);
|
||||
}
|
||||
|
||||
#footer
|
||||
{
|
||||
border: 1px solid black;
|
||||
width: 90%;
|
||||
margin-top: 50px;
|
||||
margin-left: 5%;
|
||||
margin-bottom: 10Opx;
|
||||
padding: 5px;
|
||||
background-color: rgb(237,224,213);
|
||||
}
|
||||
|
||||
|
||||
.ico {width:2%}
|
||||
.titre { width:61%; }
|
||||
.nombremessages { width:2%; }
|
||||
.nombrevu { width:4%; }
|
||||
.nombresujets { width:2%; }
|
||||
.auteur { width:7%; }
|
||||
.derniermessage { width:18%; }
|
||||
.categorie { width:92%; background-color : rgb(244,238,250); }
|
||||
|
||||
td { border: 1px solid black; background-color: rgb(253,244,223); vertical-align:top; }
|
||||
table { background-color: rgb(237,224,213); border: 1px solid black; }
|
||||
th { background-color: rgb(243,250,223); border: 1px solid black; }
|
||||
|
||||
label {
|
||||
display:block;
|
||||
width:150px;
|
||||
float:left;
|
||||
}
|
||||
15
inscription/deconnexion.php
Normal file
15
inscription/deconnexion.php
Normal file
@@ -0,0 +1,15 @@
|
||||
<?php
|
||||
session_start();
|
||||
session_destroy();
|
||||
$titre="Déconnexion";
|
||||
include("includes/debut.php");
|
||||
include("includes/menu.php");
|
||||
|
||||
if ($id==0) erreur(ERR_IS_NOT_CO);
|
||||
|
||||
echo '<p>Vous êtes à présent déconnecté <br />
|
||||
Cliquez <a href="'.htmlspecialchars($_SERVER['HTTP_REFERER']).'">ici</a>
|
||||
pour revenir à la page précédente.<br />
|
||||
Cliquez <a href="./index.php">ici</a> pour revenir à la page principale</p>';
|
||||
echo '</div></body></html>';
|
||||
?>
|
||||
10
inscription/includes/constants.php
Normal file
10
inscription/includes/constants.php
Normal file
@@ -0,0 +1,10 @@
|
||||
<?php
|
||||
define('VISITEUR',1);
|
||||
define('INSCRIT',2);
|
||||
define('MODO',3);
|
||||
define('ADMIN',4);
|
||||
?>
|
||||
|
||||
<?php
|
||||
define('ERR_IS_CO','Vous ne pouvez pas accéder à cette page si vous n\'êtes pas connecté');
|
||||
?>
|
||||
29
inscription/includes/debut.php
Normal file
29
inscription/includes/debut.php
Normal file
@@ -0,0 +1,29 @@
|
||||
<!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>
|
||||
<?php
|
||||
//Si le titre est indiqué, on l'affiche entre les balises <title>
|
||||
echo (!empty($titre))?'<title>'.$titre.'</title>':'<title> Forum </title>';
|
||||
?>
|
||||
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
|
||||
<link rel="stylesheet" media="screen" type="text/css" title="Design" href="./css/design.css" />
|
||||
</head>
|
||||
<?php
|
||||
|
||||
//Attribution des variables de session
|
||||
$lvl=(isset($_SESSION['level']))?(int) $_SESSION['level']:1;
|
||||
$id=(isset($_SESSION['id']))?(int) $_SESSION['id']:0;
|
||||
$pseudo=(isset($_SESSION['pseudo']))?$_SESSION['pseudo']:'';
|
||||
|
||||
//On inclue les 2 pages restantes
|
||||
include("./includes/functions.php");
|
||||
include("./includes/constants.php");
|
||||
?>
|
||||
|
||||
<?php
|
||||
$balises=(isset($balises))?$balises:0;
|
||||
if($balises)
|
||||
{
|
||||
//Inclure le script
|
||||
}
|
||||
?>
|
||||
21
inscription/includes/functions.php
Normal file
21
inscription/includes/functions.php
Normal file
@@ -0,0 +1,21 @@
|
||||
<?php
|
||||
function erreur($err='')
|
||||
{
|
||||
$mess=($err!='')? $err:'Une erreur inconnue s\'est produite';
|
||||
exit('<p>'.$mess.'</p>
|
||||
<p>Cliquez <a href="./index.php">ici</a> pour revenir à la page d\'accueil</p></div></body></html>');
|
||||
}
|
||||
?>
|
||||
|
||||
|
||||
<?php
|
||||
function move_avatar($avatar)
|
||||
{
|
||||
$extension_upload = strtolower(substr( strrchr($avatar['name'], '.') ,1));
|
||||
$name = time();
|
||||
$nomavatar = str_replace(' ','',$name).".".$extension_upload;
|
||||
$name = "./images/avatars/".str_replace(' ','',$name).".".$extension_upload;
|
||||
move_uploaded_file($avatar['tmp_name'],$name);
|
||||
return $nomavatar;
|
||||
}
|
||||
?>
|
||||
10
inscription/includes/identifiants.php
Normal file
10
inscription/includes/identifiants.php
Normal file
@@ -0,0 +1,10 @@
|
||||
<?php
|
||||
try
|
||||
{
|
||||
$db = new PDO('mysql:host=localhost;dbname=inscription', 'root', '');
|
||||
}
|
||||
catch (Exception $e)
|
||||
{
|
||||
die('Erreur : ' . $e->getMessage());
|
||||
}
|
||||
?>
|
||||
21
inscription/includes/menu.php
Normal file
21
inscription/includes/menu.php
Normal file
@@ -0,0 +1,21 @@
|
||||
<?php
|
||||
echo '<body>
|
||||
<div id="banniere"></div>
|
||||
<div id="menu">
|
||||
<div class="element_menu">
|
||||
<h3>Mes options</h3>
|
||||
<ul>
|
||||
<li><a href="./connexion.php">Connexion</a></li>
|
||||
<li><a href="./deconnexion.php">Deconnexion</a></li>
|
||||
</ul>
|
||||
</div>
|
||||
<div class="element_menu">
|
||||
<h3>Navigation</h3>
|
||||
<ul>
|
||||
<li><a href="./voirprofil.php">ModifProfil</a></li>
|
||||
<li><a href="./voirprofil.php">Profil</a></li>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
<div id="corps_forum">';
|
||||
?>
|
||||
126
inscription/index.php
Normal file
126
inscription/index.php
Normal file
@@ -0,0 +1,126 @@
|
||||
<?php
|
||||
//Cette fonction doit être appelée avant tout code html
|
||||
session_start();
|
||||
|
||||
//On donne ensuite un titre à la page, puis on appelle notre fichier debut.php
|
||||
$titre = "Index du forum";
|
||||
include("includes/identifiants.php");
|
||||
include("includes/debut.php");
|
||||
include("includes/menu.php");
|
||||
echo'<i>Vous êtes ici : </i><a href ="./index.php">Index du forum</a>';
|
||||
?>
|
||||
|
||||
<h1>Mon super forum</h1>
|
||||
|
||||
<?php
|
||||
//Initialisation de deux variables
|
||||
$totaldesmessages = 0;
|
||||
$categorie = NULL;
|
||||
?>
|
||||
<?php
|
||||
|
||||
//Cette requête permet d'obtenir tout sur le forum
|
||||
$query=$db->prepare('SELECT cat_id, cat_nom,
|
||||
forum_forum.forum_id, forum_name, forum_desc, forum_post, forum_topic, auth_view, forum_topic.topic_id, forum_topic.topic_post, post_id, post_time, post_createur, membre_pseudo,
|
||||
membre_id
|
||||
FROM forum_categorie
|
||||
LEFT JOIN forum_forum ON forum_categorie.cat_id = forum_forum.forum_cat_id
|
||||
LEFT JOIN forum_post ON forum_post.post_id = forum_forum.forum_last_post_id
|
||||
LEFT JOIN forum_topic ON forum_topic.topic_id = forum_post.topic_id
|
||||
LEFT JOIN forum_membres ON forum_membres.membre_id = forum_post.post_createur
|
||||
WHERE auth_view <= :lvl
|
||||
ORDER BY cat_ordre, forum_ordre DESC');
|
||||
$query->bindValue(':lvl',$lvl,PDO::PARAM_INT);
|
||||
$query->execute();
|
||||
?>
|
||||
|
||||
<table>
|
||||
<?php
|
||||
//Début de la boucle
|
||||
while($data = $query->fetch())
|
||||
{
|
||||
//On affiche chaque catégorie
|
||||
if( $categorie != $data['cat_id'] )
|
||||
{
|
||||
//Si c'est une nouvelle catégorie on l'affiche
|
||||
|
||||
$categorie = $data['cat_id'];
|
||||
?>
|
||||
<tr>
|
||||
<th></th>
|
||||
<th class="titre"><strong><?php echo stripslashes(htmlspecialchars($data['cat_nom'])); ?>
|
||||
</strong></th>
|
||||
<th class="nombremessages"><strong>Sujets</strong></th>
|
||||
<th class="nombresujets"><strong>Messages</strong></th>
|
||||
<th class="derniermessage"><strong>Dernier message</strong></th>
|
||||
</tr>
|
||||
<?php
|
||||
|
||||
}
|
||||
|
||||
//Ici, on met le contenu de chaque catégorie
|
||||
?>
|
||||
<?php
|
||||
// Ce super echo de la mort affiche tous
|
||||
// les forums en détail : description, nombre de réponses etc...
|
||||
|
||||
echo'<tr><td><img src="./images/message.gif" alt="message" /></td>
|
||||
<td class="titre"><strong>
|
||||
<a href="./voirforum.php?f='.$data['forum_id'].'">
|
||||
'.stripslashes(htmlspecialchars($data['forum_name'])).'</a></strong>
|
||||
<br />'.nl2br(stripslashes(htmlspecialchars($data['forum_desc']))).'</td>
|
||||
<td class="nombresujets">'.$data['forum_topic'].'</td>
|
||||
<td class="nombremessages">'.$data['forum_post'].'</td>';
|
||||
|
||||
// Deux cas possibles :
|
||||
// Soit il y a un nouveau message, soit le forum est vide
|
||||
if (!empty($data['forum_post']))
|
||||
{
|
||||
//Selection dernier message
|
||||
$nombreDeMessagesParPage = 15;
|
||||
$nbr_post = $data['topic_post'] +1;
|
||||
$page = ceil($nbr_post / $nombreDeMessagesParPage);
|
||||
|
||||
echo'<td class="derniermessage">
|
||||
'.date('H\hi \l\e d/M/Y',$data['post_time']).'<br />
|
||||
<a href="./voirprofil.php?m='.stripslashes(htmlspecialchars($data['membre_id'])).'&action=consulter">'.$data['membre_pseudo'].' </a>
|
||||
<a href="./voirtopic.php?t='.$data['topic_id'].'&page='.$page.'#p_'.$data['post_id'].'">
|
||||
<img src="./images/go.gif" alt="go" /></a></td></tr>';
|
||||
|
||||
}
|
||||
else
|
||||
{
|
||||
echo'<td class="nombremessages">Pas de message</td></tr>';
|
||||
}
|
||||
|
||||
//Cette variable stock le nombre de messages, on la met à jour
|
||||
$totaldesmessages += $data['forum_post'];
|
||||
|
||||
//On ferme notre boucle et nos balises
|
||||
} //fin de la boucle
|
||||
$query->CloseCursor();
|
||||
echo '</table></div>';
|
||||
?>
|
||||
<?php
|
||||
//Le pied de page ici :
|
||||
echo'<div id="footer">
|
||||
<h2>
|
||||
Qui est en ligne ?
|
||||
</h2>
|
||||
';
|
||||
|
||||
//On compte les membres
|
||||
$TotalDesMembres = $db->query('SELECT COUNT(*) FROM forum_membres')->fetchColumn();
|
||||
$query->CloseCursor();
|
||||
$query = $db->query('SELECT membre_pseudo, membre_id FROM forum_membres ORDER BY membre_id DESC LIMIT 0, 1');
|
||||
$data = $query->fetch();
|
||||
$derniermembre = stripslashes(htmlspecialchars($data['membre_pseudo']));
|
||||
|
||||
echo'<p>Le total des messages du forum est <strong>'.$totaldesmessages.'</strong>.<br />';
|
||||
echo'Le site et le forum comptent <strong>'.$TotalDesMembres.'</strong> membres.<br />';
|
||||
echo'Le dernier membre est <a href="./voirprofil.php?m='.$data['membre_id'].'&action=consulter">'.$derniermembre.'</a>.</p>';
|
||||
$query->CloseCursor();
|
||||
?>
|
||||
</div>
|
||||
</body>
|
||||
</html>
|
||||
21
inscription/menu.php
Normal file
21
inscription/menu.php
Normal file
@@ -0,0 +1,21 @@
|
||||
<?php
|
||||
echo '<body>
|
||||
<div id="banniere"></div>
|
||||
<div id="menu">
|
||||
<div class="element_menu">
|
||||
<h3>Mes options</h3>
|
||||
<ul>
|
||||
<li><a href="./connexion.php">Connexion</a></li>
|
||||
<li><a href="./deconnexion.php">Deconnexion</a></li>
|
||||
</ul>
|
||||
</div>
|
||||
<div class="element_menu">
|
||||
<h3>Navigation</h3>
|
||||
<ul>
|
||||
<li>Page 1</li>
|
||||
<li>Page 2</li>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
<div id="corps_forum">';
|
||||
?>
|
||||
230
inscription/register.php
Normal file
230
inscription/register.php
Normal file
@@ -0,0 +1,230 @@
|
||||
<?php
|
||||
session_start();
|
||||
$titre="Enregistrement";
|
||||
include("includes/identifiants.php");
|
||||
include("includes/debut.php");
|
||||
include("includes/menu.php");
|
||||
echo '<p><i>Vous êtes ici</i> : <a href="./index.php">Index du forum</a> --> Enregistrement';
|
||||
|
||||
if ($id!=0) erreur(ERR_IS_CO);
|
||||
?>
|
||||
<?php
|
||||
if (empty($_POST['pseudo'])) // Si on la variable est vide, on peut considérer qu'on est sur la page de formulaire
|
||||
{
|
||||
echo '<h1>Inscription 1/2</h1>';
|
||||
echo '<form method="post" action="register.php" enctype="multipart/form-data">
|
||||
<fieldset><legend>Identifiants</legend>
|
||||
<label for="pseudo">* Pseudo :</label> <input name="pseudo" type="text" id="pseudo" /> (le pseudo doit contenir entre 3 et 15 caractères)<br />
|
||||
<label for="password">* Mot de Passe :</label><input type="password" name="password" id="password" /><br />
|
||||
<label for="confirm">* Confirmer le mot de passe :</label><input type="password" name="confirm" id="confirm" />
|
||||
</fieldset>
|
||||
<fieldset><legend>Contacts</legend>
|
||||
<label for="email">* Votre adresse Mail :</label><input type="text" name="email" id="email" /><br />
|
||||
<label for="msn">Votre adresse MSN :</label><input type="text" name="msn" id="msn" /><br />
|
||||
<label for="website">Votre site web :</label><input type="text" name="website" id="website" />
|
||||
</fieldset>
|
||||
<fieldset><legend>Informations supplémentaires</legend>
|
||||
<label for="localisation">Localisation :</label><input type="text" name="localisation" id="localisation" />
|
||||
</fieldset>
|
||||
<fieldset><legend>Profil sur le forum</legend>
|
||||
<label for="avatar">Choisissez votre avatar :</label><input type="file" name="avatar" id="avatar" />(Taille max : 10Ko<br />
|
||||
<label for="signature">Signature :</label><textarea cols="40" rows="4" name="signature" id="signature">La signature est limitée à 200 caractères</textarea>
|
||||
</fieldset>
|
||||
<p>Les champs précédés d un * sont obligatoires</p>
|
||||
<p><input type="submit" value="S\'inscrire" /></p></form>
|
||||
</div>
|
||||
</body>
|
||||
</html>';
|
||||
|
||||
|
||||
} //Fin de la partie formulaire
|
||||
|
||||
else //On est dans le cas traitement
|
||||
{
|
||||
$pseudo_erreur1 = NULL;
|
||||
$pseudo_erreur2 = NULL;
|
||||
$mdp_erreur = NULL;
|
||||
$email_erreur1 = NULL;
|
||||
$email_erreur2 = NULL;
|
||||
$msn_erreur = NULL;
|
||||
$signature_erreur = NULL;
|
||||
$avatar_erreur = NULL;
|
||||
$avatar_erreur1 = NULL;
|
||||
$avatar_erreur2 = NULL;
|
||||
$avatar_erreur3 = NULL;
|
||||
?>
|
||||
|
||||
<?php
|
||||
|
||||
//On récupère les variables
|
||||
$i = 0;
|
||||
$temps = time();
|
||||
$pseudo=$_POST['pseudo'];
|
||||
$signature = $_POST['signature'];
|
||||
$email = $_POST['email'];
|
||||
$msn = $_POST['msn'];
|
||||
$website = $_POST['website'];
|
||||
$localisation = $_POST['localisation'];
|
||||
$pass = md5($_POST['password']);
|
||||
$confirm = md5($_POST['confirm']);
|
||||
|
||||
//Vérification du pseudo
|
||||
$query=$db->prepare('SELECT COUNT(*) AS nbr FROM forum_membres WHERE membre_pseudo =:pseudo');
|
||||
$query->bindValue(':pseudo',$pseudo, PDO::PARAM_STR);
|
||||
$query->execute();
|
||||
$pseudo_free=($query->fetchColumn()==0)?1:0;
|
||||
$query->CloseCursor();
|
||||
if(!$pseudo_free)
|
||||
{
|
||||
$pseudo_erreur1 = "Votre pseudo est déjà utilisé par un membre";
|
||||
$i++;
|
||||
}
|
||||
|
||||
if (strlen($pseudo) < 3 || strlen($pseudo) > 15)
|
||||
{
|
||||
$pseudo_erreur2 = "Votre pseudo est soit trop grand, soit trop petit";
|
||||
$i++;
|
||||
}
|
||||
|
||||
//Vérification du mdp
|
||||
if ($pass != $confirm || empty($confirm) || empty($pass))
|
||||
{
|
||||
$mdp_erreur = "Votre mot de passe et votre confirmation diffèrent, ou sont vides";
|
||||
$i++;
|
||||
}
|
||||
?>
|
||||
<?php
|
||||
$query=$db->prepare('SELECT COUNT(*) AS nbr FROM forum_membres WHERE membre_pseudo =:pseudo');
|
||||
$query->bindValue(':pseudo',$pseudo, PDO::PARAM_STR);
|
||||
$query->execute();
|
||||
$pseudo_free=($query->fetchColumn()==0)?1:0;
|
||||
?>
|
||||
<?php
|
||||
//Vérification de l'adresse email
|
||||
|
||||
//Il faut que l'adresse email n'ait jamais été utilisée
|
||||
$query=$db->prepare('SELECT COUNT(*) AS nbr FROM forum_membres WHERE membre_email =:mail');
|
||||
$query->bindValue(':mail',$email, PDO::PARAM_STR);
|
||||
$query->execute();
|
||||
$mail_free=($query->fetchColumn()==0)?1:0;
|
||||
$query->CloseCursor();
|
||||
|
||||
if(!$mail_free)
|
||||
{
|
||||
$email_erreur1 = "Votre adresse email est déjà utilisée par un membre";
|
||||
$i++;
|
||||
}
|
||||
//On vérifie la forme maintenant
|
||||
if (!preg_match("#^[a-zA-Z0-9._-]+@[a-zA-Z0-9._-]{2,}\.[a-z]{2,4}$#", $email) || empty($email))
|
||||
{
|
||||
$email_erreur2 = "Votre adresse E-Mail n'a pas un format valide";
|
||||
$i++;
|
||||
}
|
||||
//Vérification de l'adresse MSN
|
||||
if (!preg_match("#^[a-zA-Z0-9._-]+@[a-zA-Z0-9._-]{2,}\.[a-z]{2,4}$#", $msn) && !empty($msn))
|
||||
{
|
||||
$msn_erreur = "Votre adresse MSN n'a pas un format valide";
|
||||
$i++;
|
||||
}
|
||||
//Vérification de la signature
|
||||
if (strlen($signature) > 200)
|
||||
{
|
||||
$signature_erreur = "Votre signature est trop longue";
|
||||
$i++;
|
||||
}
|
||||
?>
|
||||
|
||||
<?php
|
||||
//Vérification de l'avatar :
|
||||
if (!empty($_FILES['avatar']['size']))
|
||||
{
|
||||
//On définit les variables :
|
||||
$maxsize = 10024; //Poid de l'image
|
||||
$maxwidth = 100; //Largeur de l'image
|
||||
$maxheight = 100; //Longueur de l'image
|
||||
$extensions_valides = array( 'jpg' , 'jpeg' , 'gif' , 'png', 'bmp' ); //Liste des extensions valides
|
||||
|
||||
if ($_FILES['avatar']['error'] > 0)
|
||||
{
|
||||
$avatar_erreur = "Erreur lors du transfert de l'avatar : ";
|
||||
}
|
||||
if ($_FILES['avatar']['size'] > $maxsize)
|
||||
{
|
||||
$i++;
|
||||
$avatar_erreur1 = "Le fichier est trop gros : (<strong>".$_FILES['avatar']['size']." Octets</strong> contre <strong>".$maxsize." Octets</strong>)";
|
||||
}
|
||||
|
||||
$image_sizes = getimagesize($_FILES['avatar']['tmp_name']);
|
||||
if ($image_sizes[0] > $maxwidth OR $image_sizes[1] > $maxheight)
|
||||
{
|
||||
$i++;
|
||||
$avatar_erreur2 = "Image trop large ou trop longue :
|
||||
(<strong>".$image_sizes[0]."x".$image_sizes[1]."</strong> contre <strong>".$maxwidth."x".$maxheight."</strong>)";
|
||||
}
|
||||
|
||||
$extension_upload = strtolower(substr( strrchr($_FILES['avatar']['name'], '.') ,1));
|
||||
if (!in_array($extension_upload,$extensions_valides) )
|
||||
{
|
||||
$i++;
|
||||
$avatar_erreur3 = "Extension de l'avatar incorrecte";
|
||||
}
|
||||
}
|
||||
?>
|
||||
|
||||
<?php
|
||||
if ($i==0)
|
||||
{
|
||||
echo'<h1>Inscription terminée</h1>';
|
||||
echo'<p>Bienvenue '.stripslashes(htmlspecialchars($_POST['pseudo'])).' vous êtes maintenant inscrit sur le forum</p>
|
||||
<p>Cliquez <a href="./index.php">ici</a> pour revenir à la page d accueil</p>';
|
||||
|
||||
//La ligne suivante sera commentée plus bas
|
||||
$nomavatar=(!empty($_FILES['avatar']['size']))?move_avatar($_FILES['avatar']):'';
|
||||
|
||||
$query=$db->prepare('INSERT INTO forum_membres (membre_pseudo, membre_mdp, membre_email,
|
||||
membre_msn, membre_siteweb, membre_avatar,
|
||||
membre_signature, membre_localisation, membre_inscrit,
|
||||
membre_derniere_visite)
|
||||
VALUES (:pseudo, :pass, :email, :msn, :website, :nomavatar, :signature, :localisation, :temps, :temps)');
|
||||
$query->bindValue(':pseudo', $pseudo, PDO::PARAM_STR);
|
||||
$query->bindValue(':pass', $pass, PDO::PARAM_INT);
|
||||
$query->bindValue(':email', $email, PDO::PARAM_STR);
|
||||
$query->bindValue(':msn', $msn, PDO::PARAM_STR);
|
||||
$query->bindValue(':website', $website, PDO::PARAM_STR);
|
||||
$query->bindValue(':nomavatar', $nomavatar, PDO::PARAM_STR);
|
||||
$query->bindValue(':signature', $signature, PDO::PARAM_STR);
|
||||
$query->bindValue(':localisation', $localisation, PDO::PARAM_STR);
|
||||
$query->bindValue(':temps', $temps, PDO::PARAM_INT);
|
||||
$query->execute();
|
||||
|
||||
//Et on définit les variables de sessions
|
||||
$_SESSION['pseudo'] = $pseudo;
|
||||
$_SESSION['id'] = $db->lastInsertId(); ;
|
||||
$_SESSION['level'] = 2;
|
||||
$query->CloseCursor();
|
||||
}
|
||||
else
|
||||
{
|
||||
echo'<h1>Inscription interrompue</h1>';
|
||||
echo'<p>Une ou plusieurs erreurs se sont produites pendant l incription</p>';
|
||||
echo'<p>'.$i.' erreur(s)</p>';
|
||||
echo'<p>'.$pseudo_erreur1.'</p>';
|
||||
echo'<p>'.$pseudo_erreur2.'</p>';
|
||||
echo'<p>'.$mdp_erreur.'</p>';
|
||||
echo'<p>'.$email_erreur1.'</p>';
|
||||
echo'<p>'.$email_erreur2.'</p>';
|
||||
echo'<p>'.$msn_erreur.'</p>';
|
||||
echo'<p>'.$signature_erreur.'</p>';
|
||||
echo'<p>'.$avatar_erreur.'</p>';
|
||||
echo'<p>'.$avatar_erreur1.'</p>';
|
||||
echo'<p>'.$avatar_erreur2.'</p>';
|
||||
echo'<p>'.$avatar_erreur3.'</p>';
|
||||
|
||||
echo'<p>Cliquez <a href="./register.php">ici</a> pour recommencer</p>';
|
||||
}
|
||||
}
|
||||
?>
|
||||
</div>
|
||||
</body>
|
||||
</html>
|
||||
|
||||
321
inscription/voirprofil.php
Normal file
321
inscription/voirprofil.php
Normal file
@@ -0,0 +1,321 @@
|
||||
<?php
|
||||
session_start();
|
||||
$titre="Profil";
|
||||
include("includes/identifiants.php");
|
||||
include("includes/debut.php");
|
||||
include("includes/menu.php");
|
||||
//On récupère la valeur de nos variables passées par URL
|
||||
$action = isset($_GET['action'])?htmlspecialchars($_GET['action']):'consulter';
|
||||
$membre = isset($_GET['m'])?(int) $_GET['m']:'';
|
||||
?>
|
||||
<?php
|
||||
//On regarde la valeur de la variable $action
|
||||
switch($action)
|
||||
{
|
||||
//Si c'est "consulter"
|
||||
case "consulter":
|
||||
//On récupère les infos du membre
|
||||
$query=$db->prepare('SELECT membre_pseudo, membre_avatar,
|
||||
membre_email, membre_msn, membre_signature, membre_siteweb, membre_post,
|
||||
membre_inscrit, membre_localisation
|
||||
FROM forum_membres WHERE membre_id=:membre');
|
||||
$query->bindValue(':membre',$membre, PDO::PARAM_INT);
|
||||
$query->execute();
|
||||
$data=$query->fetch();
|
||||
|
||||
//On affiche les infos sur le membre
|
||||
echo '<p><i>Vous êtes ici</i> : <a href="./index.php">Index du forum</a> -->
|
||||
profil de '.stripslashes(htmlspecialchars($data['membre_pseudo']));
|
||||
echo'<h1>Profil de '.stripslashes(htmlspecialchars($data['membre_pseudo'])).'</h1>';
|
||||
|
||||
echo'<img src="./images/avatars/'.$data['membre_avatar'].'"
|
||||
alt="Ce membre n a pas d avatar" />';
|
||||
|
||||
echo'<p><strong>Adresse E-Mail : </strong>
|
||||
<a href="mailto:'.stripslashes($data['membre_email']).'">
|
||||
'.stripslashes(htmlspecialchars($data['membre_email'])).'</a><br />';
|
||||
|
||||
echo'<strong>MSN Messenger : </strong>'.stripslashes(htmlspecialchars($data['membre_msn'])).'<br />';
|
||||
|
||||
echo'<strong>Site Web : </strong>
|
||||
<a href="'.stripslashes($data['membre_siteweb']).'">'.stripslashes(htmlspecialchars($data['membre_siteweb'])).'</a>
|
||||
<br /><br />';
|
||||
|
||||
echo'Ce membre est inscrit depuis le
|
||||
<strong>'.date('d/m/Y',$data['membre_inscrit']).'</strong>
|
||||
et a posté <strong>'.$data['membre_post'].'</strong> messages
|
||||
<br /><br />';
|
||||
echo'<strong>Localisation : </strong>'.stripslashes(htmlspecialchars($data['membre_localisation'])).'
|
||||
</p>';
|
||||
$query->CloseCursor();
|
||||
break;
|
||||
?>
|
||||
<?php
|
||||
//Si on choisit de modifier son profil
|
||||
case "modifier":
|
||||
if (empty($_POST['sent'])) // Si on la variable est vide, on peut considérer qu'on est sur la page de formulaire
|
||||
{
|
||||
//On commence par s'assurer que le membre est connecté
|
||||
if ($id==0) erreur(ERR_IS_NOT_CO);
|
||||
|
||||
//On prend les infos du membre
|
||||
$query=$db->prepare('SELECT membre_pseudo, membre_email,
|
||||
membre_siteweb, membre_signature, membre_msn, membre_localisation,
|
||||
membre_avatar
|
||||
FROM forum_membres WHERE membre_id=:id');
|
||||
$query->bindValue(':id',$id,PDO::PARAM_INT);
|
||||
$query->execute();
|
||||
$data=$query->fetch();
|
||||
echo '<p><i>Vous êtes ici</i> : <a href="./index.php">Index du forum</a> --> Modification du profil';
|
||||
echo '<h1>Modifier son profil</h1>';
|
||||
|
||||
echo '<form method="post" action="voirprofil.php?action=modifier" enctype="multipart/form-data">
|
||||
|
||||
|
||||
<fieldset><legend>Identifiants</legend>
|
||||
Pseudo : <strong>'.stripslashes(htmlspecialchars($data['membre_pseudo'])).'</strong><br />
|
||||
<label for="password">Nouveau mot de Passe :</label>
|
||||
<input type="password" name="password" id="password" /><br />
|
||||
<label for="confirm">Confirmer le mot de passe :</label>
|
||||
<input type="password" name="confirm" id="confirm" />
|
||||
</fieldset>
|
||||
|
||||
<fieldset><legend>Contacts</legend>
|
||||
<label for="email">Votre adresse E_Mail :</label>
|
||||
<input type="text" name="email" id="email"
|
||||
value="'.stripslashes($data['membre_email']).'" /><br />
|
||||
|
||||
<label for="msn">Votre adresse MSN :</label>
|
||||
<input type="text" name="msn" id="msn"
|
||||
value="'.stripslashes($data['membre_msn']).'" /><br />
|
||||
|
||||
<label for="website">Votre site web :</label>
|
||||
<input type="text" name="website" id="website"
|
||||
value="'.stripslashes($data['membre_siteweb']).'" /><br />
|
||||
</fieldset>
|
||||
|
||||
<fieldset><legend>Informations supplémentaires</legend>
|
||||
<label for="localisation">Localisation :</label>
|
||||
<input type="text" name="localisation" id="localisation"
|
||||
value="'.stripslashes($data['membre_localisation']).'" /><br />
|
||||
</fieldset>
|
||||
|
||||
<fieldset><legend>Profil sur le forum</legend>
|
||||
<label for="avatar">Changer votre avatar :</label>
|
||||
<input type="file" name="avatar" id="avatar" />
|
||||
(Taille max : 10 ko)<br /><br />
|
||||
<label><input type="checkbox" name="delete" value="Delete" />
|
||||
Supprimer l avatar</label>
|
||||
Avatar actuel :
|
||||
<img src="./images/avatars/'.$data['membre_avatar'].'"
|
||||
alt="pas d avatar" />
|
||||
|
||||
<br /><br />
|
||||
<label for="signature">Signature :</label>
|
||||
<textarea cols="40" rows="4" name="signature" id="signature">
|
||||
'.stripslashes($data['membre_signature']).'</textarea>
|
||||
|
||||
|
||||
</fieldset>
|
||||
<p>
|
||||
<input type="submit" value="Modifier son profil" />
|
||||
<input type="hidden" id="sent" name="sent" value="1" />
|
||||
</p></form>';
|
||||
$query->CloseCursor();
|
||||
}
|
||||
else //Sinon on est dans la page de traitement
|
||||
{
|
||||
|
||||
//On déclare les variables
|
||||
|
||||
$mdp_erreur = NULL;
|
||||
$email_erreur1 = NULL;
|
||||
$email_erreur2 = NULL;
|
||||
$msn_erreur = NULL;
|
||||
$signature_erreur = NULL;
|
||||
$avatar_erreur = NULL;
|
||||
$avatar_erreur1 = NULL;
|
||||
$avatar_erreur2 = NULL;
|
||||
$avatar_erreur3 = NULL;
|
||||
|
||||
//Encore et toujours notre belle variable $i :p
|
||||
$i = 0;
|
||||
$temps = time();
|
||||
$signature = $_POST['signature'];
|
||||
$email = $_POST['email'];
|
||||
$msn = $_POST['msn'];
|
||||
$website = $_POST['website'];
|
||||
$localisation = $_POST['localisation'];
|
||||
$pass = md5($_POST['password']);
|
||||
$confirm = md5($_POST['confirm']);
|
||||
|
||||
|
||||
//Vérification du mdp
|
||||
if ($pass != $confirm || empty($confirm) || empty($pass))
|
||||
{
|
||||
$mdp_erreur = "Votre mot de passe et votre confirmation diffèrent ou sont vides";
|
||||
$i++;
|
||||
}
|
||||
|
||||
//Vérification de l'adresse email
|
||||
//Il faut que l'adresse email n'ait jamais été utilisée (sauf si elle n'a pas été modifiée)
|
||||
|
||||
//On commence donc par récupérer le mail
|
||||
$query=$db->prepare('SELECT membre_email FROM forum_membres WHERE membre_id =:id');
|
||||
$query->bindValue(':id',$id,PDO::PARAM_INT);
|
||||
$query->execute();
|
||||
$data=$query->fetch();
|
||||
if (strtolower($data['membre_email']) != strtolower($email))
|
||||
{
|
||||
//Il faut que l'adresse email n'ait jamais été utilisée
|
||||
$query=$db->prepare('SELECT COUNT(*) AS nbr FROM forum_membres WHERE membre_email =:mail');
|
||||
$query->bindValue(':mail',$email,PDO::PARAM_STR);
|
||||
$query->execute();
|
||||
$mail_free=($query->fetchColumn()==0)?1:0;
|
||||
$query->CloseCursor();
|
||||
if(!$mail_free)
|
||||
{
|
||||
$email_erreur1 = "Votre adresse email est déjà utilisé par un membre";
|
||||
$i++;
|
||||
}
|
||||
|
||||
//On vérifie la forme maintenant
|
||||
if (!preg_match("#^[a-z0-9A-Z._-]+@[a-z0-9._-]{2,}\.[a-z]{2,4}$#", $email) || empty($email))
|
||||
{
|
||||
$email_erreur2 = "Votre nouvelle adresse E-Mail n'a pas un format valide";
|
||||
$i++;
|
||||
}
|
||||
}
|
||||
//Vérification de l’adresse MSN
|
||||
if (!preg_match("#^[a-z0-9._-]+@[a-z0-9._-]{2,}\.[a-z]{2,4}$#", $msn) && !empty($msn))
|
||||
{
|
||||
$msn_erreur = "Votre nouvelle adresse MSN n'a pas un format valide";
|
||||
$i++;
|
||||
}
|
||||
|
||||
//Vérification de la signature
|
||||
if (strlen($signature) > 200)
|
||||
{
|
||||
$signature_erreur = "Votre nouvelle signature est trop longue";
|
||||
$i++;
|
||||
}
|
||||
|
||||
|
||||
//Vérification de l'avatar
|
||||
|
||||
if (!empty($_FILES['avatar']['size']))
|
||||
{
|
||||
//On définit les variables :
|
||||
$maxsize = 30072; //Poid de l'image
|
||||
$maxwidth = 100; //Largeur de l'image
|
||||
$maxheight = 100; //Longueur de l'image
|
||||
//Liste des extensions valides
|
||||
$extensions_valides = array( 'jpg' , 'jpeg' , 'gif' , 'png', 'bmp' );
|
||||
|
||||
if ($_FILES['avatar']['error'] > 0)
|
||||
{
|
||||
$avatar_erreur = "Erreur lors du tranfsert de l'avatar : ";
|
||||
}
|
||||
if ($_FILES['avatar']['size'] > $maxsize)
|
||||
{
|
||||
$i++;
|
||||
$avatar_erreur1 = "Le fichier est trop gros :
|
||||
(<strong>".$_FILES['avatar']['size']." Octets</strong>
|
||||
contre <strong>".$maxsize." Octets</strong>)";
|
||||
}
|
||||
|
||||
$image_sizes = getimagesize($_FILES['avatar']['tmp_name']);
|
||||
if ($image_sizes[0] > $maxwidth OR $image_sizes[1] > $maxheight)
|
||||
{
|
||||
$i++;
|
||||
$avatar_erreur2 = "Image trop large ou trop longue :
|
||||
(<strong>".$image_sizes[0]."x".$image_sizes[1]."</strong> contre
|
||||
<strong>".$maxwidth."x".$maxheight."</strong>)";
|
||||
}
|
||||
|
||||
$extension_upload = strtolower(substr( strrchr($_FILES['avatar']['name'], '.') ,1));
|
||||
if (!in_array($extension_upload,$extensions_valides) )
|
||||
{
|
||||
$i++;
|
||||
$avatar_erreur3 = "Extension de l'avatar incorrecte";
|
||||
}
|
||||
}
|
||||
?>
|
||||
<?php
|
||||
echo '<p><i>Vous êtes ici</i> : <a href="./index.php">Index du forum</a> --> Modification du profil';
|
||||
echo '<h1>Modification d\'un profil</h1>';
|
||||
|
||||
|
||||
if ($i == 0) // Si $i est vide, il n'y a pas d'erreur
|
||||
{
|
||||
if (!empty($_FILES['avatar']['size']))
|
||||
{
|
||||
$nomavatar=move_avatar($_FILES['avatar']);
|
||||
$query=$db->prepare('UPDATE forum_membres
|
||||
SET membre_avatar = :avatar
|
||||
WHERE membre_id = :id');
|
||||
$query->bindValue(':avatar',$nomavatar,PDO::PARAM_STR);
|
||||
$query->bindValue(':id',$id,PDO::PARAM_INT);
|
||||
$query->execute();
|
||||
$query->CloseCursor();
|
||||
}
|
||||
|
||||
//Une nouveauté ici : on peut choisis de supprimer l'avatar
|
||||
if (isset($_POST['delete']))
|
||||
{
|
||||
$query=$db->prepare('UPDATE forum_membres
|
||||
SET membre_avatar=0 WHERE membre_id = :id');
|
||||
$query->bindValue(':id',$id,PDO::PARAM_INT);
|
||||
$query->execute();
|
||||
$query->CloseCursor();
|
||||
}
|
||||
|
||||
echo'<h1>Modification terminée</h1>';
|
||||
echo'<p>Votre profil a été modifié avec succès !</p>';
|
||||
echo'<p>Cliquez <a href="./index.php">ici</a>
|
||||
pour revenir à la page d accueil</p>';
|
||||
|
||||
//On modifie la table
|
||||
|
||||
$query=$db->prepare('UPDATE forum_membres
|
||||
SET membre_mdp = :mdp, membre_email=:mail, membre_msn=:msn, membre_siteweb=:website,
|
||||
membre_signature=:sign, membre_localisation=:loc
|
||||
WHERE membre_id=:id');
|
||||
$query->bindValue(':mdp',$pass,PDO::PARAM_INT);
|
||||
$query->bindValue(':mail',$email,PDO::PARAM_STR);
|
||||
$query->bindValue(':msn',$msn,PDO::PARAM_STR);
|
||||
$query->bindValue(':website',$website,PDO::PARAM_STR);
|
||||
$query->bindValue(':sign',$signature,PDO::PARAM_STR);
|
||||
$query->bindValue(':loc',$localisation,PDO::PARAM_STR);
|
||||
$query->bindValue(':id',$id,PDO::PARAM_INT);
|
||||
$query->execute();
|
||||
$query->CloseCursor();
|
||||
}
|
||||
else
|
||||
{
|
||||
echo'<h1>Modification interrompue</h1>';
|
||||
echo'<p>Une ou plusieurs erreurs se sont produites pendant la modification du profil</p>';
|
||||
echo'<p>'.$i.' erreur(s)</p>';
|
||||
echo'<p>'.$mdp_erreur.'</p>';
|
||||
echo'<p>'.$email_erreur1.'</p>';
|
||||
echo'<p>'.$email_erreur2.'</p>';
|
||||
echo'<p>'.$msn_erreur.'</p>';
|
||||
echo'<p>'.$signature_erreur.'</p>';
|
||||
echo'<p>'.$avatar_erreur.'</p>';
|
||||
echo'<p>'.$avatar_erreur1.'</p>';
|
||||
echo'<p>'.$avatar_erreur2.'</p>';
|
||||
echo'<p>'.$avatar_erreur3.'</p>';
|
||||
echo'<p> Cliquez <a href="./voirprofil.php?action=modifier">ici</a> pour recommencer</p>';
|
||||
}
|
||||
} //Fin du else
|
||||
break;
|
||||
|
||||
default; //Si jamais c'est aucun de ceux là c'est qu'il y a eu un problème :o
|
||||
echo'<p>Cette action est impossible</p>';
|
||||
|
||||
} //Fin du switch
|
||||
?>
|
||||
</div>
|
||||
</body>
|
||||
</html>
|
||||
</html>
|
||||
Reference in New Issue
Block a user