Précédent   Forum des professionnels en informatique > PHP > Langage > Débuter
Débuter Forum d'entraide pour débuter en PHP. Avant de poster -> Cours PHP, FAQ PHP, Outils PHP, etc.
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 25/04/2011, 17h02   #1
Membre du Club
 
Michael Di Blasio
Étudiant
Inscription : mai 2008
Messages : 138
Détails du profil
Informations personnelles :
Nom : Michael Di Blasio

Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : mai 2008
Messages : 138
Points : 49
Points : 49
Par défaut Problème avec gestion de session

Bonjour,
Je dois faire une authentification avec une session
et ensuite gérer des utilisateur

je fais de la manière suivante
j'ai une page index.php qui contrôle si une session existe si oui alors elle affiche la page gestion ou je peux gérer mes utilisateurs Sinon elle affiche la page authentification
voici le code de la page index.php
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
 
session_start();
	<div id="header">
    	<?php
			(isset($_SESSION['login'])) ? include_once("Pages/Gestion.php"): include_once("Pages/Authentification.php");
		?>
    </div>
    <div id="contner">
    	<?php
			if(isset($_SESSION['login'])){
				include_once($tabVal[0]['Chemin']);
			}
		?>
    </div>
voici le code de la page Authentification.php
Code :
1
2
3
4
5
6
7
8
9
 
<div class="auth">
	<form method="post" action="Pages/ValidationAuth.php">
        <p><label>Nom d'utilisateur:</label><input type="text" name="username" value="" /></p>
        <p><label>Mot de passe:</label><input type="password" name="password" value="" /></p>
        <p><input type="submit" name="valider" value="Valider" /></p>
        <p> <a href="#">Mot de passe oubli&eacute; </a></p>
    </form>
</div>
voici le de la page ou je fais le traitement de l'authentification avec une redirection meta refresh.
Code :
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
 
<?php
session_start();
?>
<!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">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta http-equiv="Refresh" content="5;URL=http://localhost/tir-reconvilier/Admin/index.php">
<title>Document sans nom</title>
	<link rel="stylesheet" type="text/css" href="../../Css/Undo.css" media="screen"/>
	<link rel="stylesheet" type="text/css" href="../../Css/Admin.css" media="screen"/>
    <script type="text/javascript" src="../../Librairies/js/jQuery-1.5.2.js"></script>
    <script type="text/javascript" src=""></script>
</head>
 
<body>
	<div class="titreRedirection">Redirection... Veuillez patientez</div>
    <div class="redirection">
    	<?php
		include_once('../Include/file.inc.php');
		if(isset($_POST['valider'])){
			$userName=$_POST['username'];
			$password=$_POST['password'];
			$strUser = new Chaine($userName);
 
			if(!$strUser->controleChaineAuth()){
				exit("nom d'utilisateur n'est pas conforme");
			}
			$strPass = new Chaine($password);
			if(!$strPass->controleChaineAuth()){
				exit("nom d'utilisateur n'est pas conforme");
			}
			$pasword = $strPass->cryptChaine();
			$pdo = Singleton::getInstance();
 
			$requestSQL = "SELECT * FROM Authentifications WHERE UserName = ? AND Password = ?";
			$objPDOStatement = $pdo->prepareRequest($requestSQL);
			if($pdo->executeRequest($objPDOStatement, array($strUser->getChaine(),$strPass->getChaine()))){
				if($pdo->getCountRow($objPDOStatement) == 1){
					$tabVal = $pdo->getFetchAll($objPDOStatement);
					$_SESSION['login'] = true;
					$_SESSION['username'] = $tabVal[0]['UserName'];
					echo "Merci de vous être authentifié ".$_SESSION['username']."<br />";
					echo" Vous serrez rediriger sur la page d'administration";
				}else{
					echo"Erreur lors de l'authentification"."<br />";
					echo"Veuillez recommencer l'authentification";
				}
			}else{
				echo"Erreur lors de l'authentification"."<br />";
				echo"Veuillez recommencer l'authentification";
			}
		}
		?>
    </div>
</body>
</html>
Jusque la tous vas bien j'ai bien ma session qui est créer avec comme variable session du nom de l'utilisateur.
quand je rappelle ma page index la session est créer et donc sa affiche la page Gestion.php
voici son code
Code :
1
2
3
4
5
6
 
<ul class="memuAdmin">
    <li><a href="index.php?pages=13">Gestion Utilisateur</a></li>
    <li><a href="index.php?pages=14">Gestion Evenement</a></li>
    <li><a href="index.php?pages=15">Gestion Photo</a></li>
</ul>
maintenant quand je clique sur Gestion Utilisateur sa vas afficher dans le contener de index.php GestUser.php
voici son code
Code :
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
 
<div class="btnGestUser">
    <ul class="menuGestUser">
        <li><a href="index.php?pages=13&action=1">Ajouter un membre</a></li>
        <li><a href="index.php?pages=13&action=2">Liste des membres</a></li>
    </ul>
</div>
<div>
<?php
	switch ($action){
		case 1:
			$chemin = "Pages/AddUser.php";
			break;
		case 2;
			$chemin = "Pages/ListUser.php";
			break;
		case 3;
			$chemin = "Pages/ModifUser.php";
			break;
		default:
			$chemin = "Pages/SelectChoseGestion.php";
			break;
	}
	include_once($chemin);
?>
</div>
quand je clique sur ajouter un membre j'ai le formulaire d'ajout qui s'affiche dans le conteneur de gestUser.php
voici le code de addUser.php
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
 
<div class="addUser">
	<fieldset>
    <legend>Ajout d'un membre</legend>
        <form method="post" action="Pages/ActionUser.php?action=1">
      <p><label>Nom:</label><input type="text" name="nom" value="<?php if(isset($_SESSION['nom'])){echo $_SESSION['nom'];} ?>" /></p>
            <p><label>Pr&eacute;nom:</label><input type="text" name="prenom" value="<?php if(isset($_SESSION['prenom'])){echo $_SESSION['prenom'];} ?>" /></p>
            <p><label>Email:</label><input type="text" name="email" value="<?php if(isset($_SESSION['email'])){echo $_SESSION['email'];} ?>" /></p>
           	<p><label>nom d'utilisateur:</label><input type="text" name="username" value="<?php if(isset($_SESSION['userName'])){echo $_SESSION['userName'];} ?>" /></p>
            <p><label>mot de passe:</label><input type="password" name="pass1" value="" /></p>
            <p><label>répeter mot de passe:</label><input type="password" name="pass2" value="" /></p>
            <p><input type="submit" name="valider" value="Valider" /></p>
        </form>
    </fieldset>
</div>
depuis ce fichier quand je clique sur valider sa me renvoi sur une page actionUser.php qui elle a une redirection meta refresh
si le contrôle de se que l'utilisateur insère dans le formulaire joue alors pas de souci l'utilisateur vient enregistrer dans la base de donnée par contre si les test de contrôle trouve que un champs est pas conforme un message est inscrit et je retourne sur la page d'addUser et la je voudrais que les champs que l'utilisateur a insérer soient garder en mémoire c'est pourquoi dans le code de actionUser.php je créer pour chaque champs une variable session.
voici le code de ActionUser.php
Code :
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
 
<?php
session_start();
?>
<!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">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta http-equiv="Refresh" content="5;<?php echo"URL=http://localhost/tir-reconvilier/Admin/index.php?pages=13 & action=".$action." & id=".$id?>">
<title>Document sans nom</title>
	<link rel="stylesheet" type="text/css" href="../../Css/Undo.css" media="screen"/>
	<link rel="stylesheet" type="text/css" href="../../Css/Admin.css" media="screen"/>
    <script type="text/javascript" src="../../Librairies/js/jQuery-1.5.2.js"></script>
    <script type="text/javascript" src=""></script>
</head>
 
<body>
	<div class="titreRedirection">Redirection... Veuillez patientez</div>
    <div class="redirection">
<?php
	switch ($action){
		case 1:
 
				$strNom = new Chaine($_POST['nom']);
				$strPrenom = new Chaine($_POST['prenom']);
				$strEmail = new Chaine($_POST['email']);
				$strUsername = new Chaine($_POST['username']);
 
				$_SESSION['nom'] = $strNom->getChaine(); 
				$_SESSION['prenom'] = $strPrenom->getChaine();
				$_SESSION['email'] = $strEmail->getChaine();
				$_SESSION['userameNewMembre'] = $strUsername->getChaine();
 
				echo $_SESSION['nom'];
				echo $_SESSION['prenom'];
				echo $_SESSION['email'];
				echo $_SESSION['userameNewMembre'];
la j'ai pas mis tous le code juste se qui nous intéressent
si je fais dans cette page un echo de mes variable de session elle s'affiche même celle créer durant authentification se qui est normal.
quand le refresh est fais, et que je retourne sur mon formulaire addUser les variable de session existe mais elle son vide

Je ne comprend pas pourquoi?

Je vous remercie par avance pour toute l'aide que vous pourrai m'amener

Di Blasio Michael
diblasio est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/04/2011, 20h25   #2
Membre émérite
 
Avatar de vorace
 
Homme
Développeur
Inscription : août 2010
Messages : 587
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France, Meurthe et Moselle (Lorraine)

Informations professionnelles :
Activité : Développeur

Informations forums :
Inscription : août 2010
Messages : 587
Points : 861
Points : 861
sur ton dernier script avant de créer tes variables de session test si elles existent, j'ai pas pu suivre tout le cheminement de tes pages mais commence par if !isset() sur chacune de tes variables de session parce qu’a mon avis tu les écrases à cette étape de ton code, pareil pour tes variable post :
Code :
1
2
3
4
5
6
7
8
9
			if(isset($_POST['nom']) && !empty($_POST['nom'])) $strNom = new Chaine($_POST['nom']);
				$strPrenom = new Chaine($_POST['prenom']);
				$strEmail = new Chaine($_POST['email']);
				$strUsername = new Chaine($_POST['username']);
 
				if(!isset($_SESSION['nom']))$_SESSION['nom'] = $strNom->getChaine(); 
				$_SESSION['prenom'] = $strPrenom->getChaine();
				$_SESSION['email'] = $strEmail->getChaine();
				$_SESSION['userameNewMembre'] = $strUsername->getChaine();
et ça pour toute les variables
__________________
Développeur informatique contrarié...
vorace est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 06h52.


 
 
 
 
Partenaires

Hébergement Web