begin process at 2012 05 30 17:45:10
  Trouver un code source :
 
dans
 
Accueil > Forum > 

PHP

 > 

Divers

 > 

Divers

 > 

Passer de variable avec HEADER()


Derniers messages déposésPoser une question dans le forum ou lancer une discussion

Passer de variable avec HEADER()

jeudi 19 juillet 2007 à 10:00:43 | Passer de variable avec HEADER()

chapata



Hello ,

voilà, j'ai un fichier "secure.php" qui vérifie s'il y a session ouverte sur le login, sinon redirige vers la page de login.php

<?php

// On vérifie si l'URL est passée en LOG OFF
if (isset($_GET['id']) =='logoff'){
   session_start();
   session_unset();
   session_destroy();
}

// On prolonge la session en l'ouvrant

session_start();

// On teste si la variable de session existe et contient une valeur

if(empty($_SESSION['session_id'])) {
   
// garde en mémoire l'URL d'accès''
   
$URL = $_SERVER['PHP_SELF'];
   
// Si session inexistante ou nulle, on redirige vers le formulaire de login avec l'URL en varaible
   
header('Location: login.php');
   
exit();
}
?>Je voudrais récupérer la varaible $URL pour que je puisse la passer et arrivée sur la page que l'utlisateur voulait initialement.
***** code login.php *****


<?PHP

//débute le calcul du temps d'execution
$btime=microtime();

//si destruction de la session pour le logoff par URL

if (isset($_GET['id']) =='logoff'){
   session_start();
   session_unset();
   session_destroy();
} elseif (!isset(
$_SESSION['session_id'])){
   session_start();
   session_unset();
   session_destroy();
}

require
(
"include/mysql.config.php");

//crée une variable : ErrMessage

$errorMessage = '';

// si envoi connection...

if(isset($_POST['login'])) {
   
// si l'identifiant et le mot de passe différents de vide ...
   
if(!empty($_POST['login']) && !empty($_POST['pass'])) {
      
// si requête SQL est valide alors ...
      
$sql = mysql_query('SELECT * FROM utilisateur WHERE login = "'.$_POST['login'].'"');
      if(!
$sql) {
         echo mysql_error(); 
         exit;
      }

      // ... vérification du login de connection
      
$nb = mysql_num_rows($sql);
      if (
$nb == '0') {
         $errorMessage = 'Identifiant incorrect !';
      } else {
         
// ... vérification du mot de passe
         
while ($data = mysql_fetch_array($sql)) {
            if (
$data['pass'] != $_POST['pass']) {
               
$errorMessage = 'Mot de passe incorrect !'
            } else {
               
// ... on ouvre la session
               
session_start();
               
// ... on enregistre le login + id + profil dans les variables de session*/
               
$_SESSION['session_id'] = $data['id'];
               $_SESSION['session_login'] = $_POST['login'];
               $_SESSION['session_profil'] = $data['profil'];
               $_SESSION['session_nom'] = $data['nom'];
               $_SESSION['session_prenom'] = $data['prenom'];
               $_SESSION['session_smiley'] = $data['smiley'];
               $_SESSION['session_mail'] = $data['email'];

               // On redirige vers le fichier ou répertoire voulu
               
if (isset($URL)){
                  if (!empty($URL)){
                     
header('Location: '.$URL.'');
                  
}
               
} else { 
                  header(
'Location: main.php'
);
               }

            exit();
            }
         }
      }
   }else{
      
$errorMessage = 'Identifiant ou mot de passe obligatoire !';
   }
}
?>

 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr">

<head>
   <title>Identification</title>
   <link rel="stylesheet" href="login.css" type="text/css" media="all" />
</head>
<body>
<div id="identity">
<form action="

<?php echo $_SERVER['PHP_SELF'] ; ?>" method="post" name="logonForm">
<table width="280px" >
   <tr class="clsTitre"><td colspan="2" align="center" >Identification Utilisateur :</td></tr>
   
<?php
   
// Rencontre-t-on une erreur ?
   
if(!empty($errorMessage)) {
      echo
'<tr><td align="center" colspan="2" class="clsError">'.htmlspecialchars      ($errorMessage).'</td></tr>';
   } else {
      echo
'<tr><td align="center" colspan="2" >&nbsp</td></tr>';
   }
?>
   
<tr><td >Identifiant : </td><td><input type="text" name="login" id="login" value="" lenght="10"/></td></tr>
   <tr><td >Mot de passe : </td><td><input type="password" name="pass" id="pass" value="" lenght="10"/> </td></tr>
   <tr><td align="center" colspan="2" >&nbsp</td></tr>
   <tr><td>&nbsp;
</td><td>
      <table class="clsConnex">
         <tr><td align="left" class="clsButton" >&nbsp;<a href="javascript:document.forms['logonForm'].submit();" >Connexion</a>&nbsp;</td></tr>
      </table>
   </td></tr>
</table>
</form>
<?php

//fin de code pour micro time

$ctime=microtime();
$dtime=substr($btime, 15, 6);
$etime=substr($ctime, 15, 6);
$btime=substr($btime, 0, 8);
$ctime=substr($ctime, 0, 8);
$btime=$btime+$dtime;
$ctime=$ctime+$etime;
$atime=$ctime-$btime;
$atime=substr($atime, 0, 8);
$ftime=substr($atime, 0, 1);
if(
$ftime <= "1"){$stime="seconde";}else{$stime="secondes";}
echo
'Temps d\'exécution en '.$atime.'&nbsp;'.$stime;
?>

</div>
</body>
</html>

Je n'ai pas de message d'erreur et si je fais un echo $URL, il me dis que cette variable n'existe pas .

merci pour votre aide



ChaPaTa
jeudi 19 juillet 2007 à 10:52:14 | Re : Passer de variable avec HEADER()

eplanet

As-tu essayé de faire include 'login.php'; ou lieu de header('Location: login.php'); ?

Vince
jeudi 19 juillet 2007 à 11:03:40 | Re : Passer de variable avec HEADER()

chapata

Marche pas ....
si un utilisateur va sur l'url : [ Lien ] sans avoir eu de connection, donc de SESSION ouverte, il est rédirigé vers http://mon_site/login.php.

Dns "ma_page_visitée.php" je require "secure.php" et include d'autre fichier.php.

Si au contraire, il s'est identifié avant, la page s'affiche avec toutes ces variable de sessions ... le menu, les entetes etc ...

Donc si je fais include() au lieu de header(), ca fait tout planter, car cela signifirai qu'il est autentifié ... alors que ce n'est pas le cas. Et les variable de sessions ne sont pas reconnu.

Il faut réellement que je trouve le moyen de stocker une variable URL que je refais passer dans ma page login.php s'il n'est pas identifié.

ChaPaTa
jeudi 19 juillet 2007 à 21:45:40 | Re : Passer de variable avec HEADER()

coucou747

Administrateur CodeS-SourceS
Salut

header('Location : url absolue')

une url relative n'est pas standard

je ne suis pas sur que ca soit la solution, mais du moins, c'est une approche :)


une recherche sur exalead vous aurait peut-etre evite de poser cette question
In a dream, I saw me, drop dead...
U were there, U cried...
It was just a dream,
if I die, U won't cry, maybe, U'll be happy
h


Cette discussion est classée dans : php, login, data, url, session


Répondre à ce message

Sujets en rapport avec ce message

[php] petit probleme !! [ par dekovince ] bonjour a tous !!alors voila, je m explique :Un formulaire, une basse de donnee avec une table, et dans cette table un champs qui se nomme compteur !! actualisation de session [ par christuckers ] Salut les CSistes !!J'ai une question concernant les sessions, dont je n'ai malheureusement pas trouvé la réponse.J'ai réalisé un site avec une frame Variables de Sessions [ par niko14 ] Bonjour tout le monde!!Voila le problème auquel je suis confronté!Je suis en traind e me remettre au Pho et je me fais un petit truc!J'ai un index qui Perte de session avec lien href [ par forcels ] Voila,je réalise actuellement un site web php permettant de gérer l'administration d'un club de ski dans le cadre de mon projet de fin d'études.Je blo $_session [ par sana83 ] salut,<td id="HB_Focus_Element" valign="top" width="100%" background= probleme de session sous easyphp-1.8 [ par mizoguchi ] salut à tous,j'ai un gros souci de session, aprés authentification de user par l'id et le mot de passe. s'ouvre à ce dernier une session dans la page PB Protections d'images par session [ par holoduke ] Bonjour à tous.Pour mon site j'ai créer un accès membre, dedant j'y ai inserer des pages avec au début:if(!isset($_SESSION['login'])) {  echo "documen utilisation des sessions [ par ralinis ] Salu a tous.jai un problème avec les sessions en php.d'abord j'ai activer les parametre a on donc le problème ne se pose pas.le code est le suivant:++ lien Html dans un IF en PHP [ par nutty91 ] bonjour, j'ai sur une page php avec Session un lien htm de typer j'ai donc fait un If en controlant les variable de session ( lo Variables de session [ par Aaron ] Bonjour,Je récupère des valeurs d'une table d'une base de données de la façon suivante :  $req = mysql_query("SELECT * FROM Users WHER


Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Mai 2012
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

Consulter la suite du CalendriCode

Photothèque

A découvrir



 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 4,212 sec (3)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales