prob avec les SESSIONs - PHP - Programmation
Marsh Posté le 07-02-2012 à 11:52:07
Bonjour tout d'abord vous devez insérer session_start(); dans toute vos page avant tout code.
En suite vous enregistrez une session avec les données d’authentification.
et en fin vous devez faire une vérification d'authentification sur chaque page avant son affichage, c à d si la session d'authentification la page sera affichée si non vous renvoyer le visiteur sur la page index pour s'authentifier.
Pour plus de précision voir ce cours sur les sessions http://apprendre-creer-sites.com/php/php-sessions.php
Marsh Posté le 08-02-2012 à 10:46:39
Est-ce que l'authentification par mdp/pwd sur BDD est compatible avec les sessions ?
j'ai bien inséré <?php session_start();/?> sur toutes mes pages, mais je ne trouve pas la manière d'imbriquer l'ouverture de session dans mon script
est-ce que je peux utiliser la même variable que celle de l'authentification ($EDITlog) vu qu'elle est déjà créé à partir de l'index1.php ?
Marsh Posté le 08-02-2012 à 11:20:53
Tout d’abord il faut créer une session quand le visiteur se connecte avec son nom d’utilisateur et son mot de passe comme suit
$_SESSION['user']= ‘nom utilisateur’;
$_SESSION['pass']= ‘mot de passe’;
en suite sur les autre pages je vérifie si les sessions user et pass existent si non je renvoie le visiteur sur la page index pour s’authentifier.
Voici le comment :
if(isset($_SESSION['user'] and $_SESSION['pass']){
//ici je compare avec ma base de données
if ($_SESSION['user']==’user de la bdd’ AND $_SESSION['pass']==’pass de la bdd){
je fait ce que je veux par exemple afficher les éléments de la page
}
}else je renvoie le visiteur sur la page index s'il n'est pas authentifié
Marsh Posté le 01-03-2012 à 11:09:47
bon bon bon
déjà merci pour vos infos, j'ai déjà pas mal avancé
j'ai dégagé les includes pour mes tests et ça marche ..... pfouuu
<?php
session_start();
$_SESSION['log'] = $EDITlog['log'];
?>
<?php
echo $_SESSION['log'];
?>
<?
mysql_connect("xxxx", "xxxx", "xxxx" );
mysql_select_db("xxxx" );
$Resultat=mysql_query("SELECT * FROM `ACCES` WHERE `log` LIKE '$EDITlog' AND `pwd` LIKE '$EDITpwd'" );
if (mysql_numrows($Resultat) ==1)
{
?>
ça serait trop beau que tout marche correctement
voici mon nouveau prob :
<?php
echo $_SESSION['log']; <- n'affiche QUE le 1er caractère du log
?>
Marsh Posté le 01-03-2012 à 13:05:18
$_SESSION['log'] = $EDITlog['log'];
Ca serait pas plutôt $_SESSION['log'] = $EDITlog; ?
PS1 : utiliser plutôt le signe = dans les requêtes SQL que LIKE. Déjà parce que = utilise les index et pas LIKE. Ensuite parce qu'un petit malin qui mettra des % dans les champs qui alimentent $EDITlog et $EDITpwd va permettre de se logger.
PS2 : as-tu traité le cas des SQL injections? J'ai peur que non à la vue de ton code
PS3 : pitié, t'as pas stocké en claire dans la BD les mots de passe?
Marsh Posté le 02-03-2012 à 12:23:08
Merci Rufo -> $_SESSION['log'] = $EDITlog; -> impec
ainsi que = au lieu de LIKE
bon sinon tu m'as démasqué mes mdp sont bien en clair pour le moment, leur cryptage est ma prochaine étape, une fois que j'en aurais fini avec mes SESSIONs
et Concernant les injections SQL ...... ça sera la suivante
pour l'instant je n'ai pas d'info sensible dans ma BDD, je construit seulement la structure
j'avance pas à pas
et surtout merci pour vous infos
Marsh Posté le 02-03-2012 à 14:35:53
Pas besoin de cryptage, juste du hashage en md5 sou sha-1 :
http://ru.php.net/manual/en/function.md5.php
http://ru.php.net/manual/en/function.sha1.php
Au lieu de faire un " where mdp ='$MonMdp' " ben tu fais " where mdp = '".md5($MonMdp)."' "
Comme ça, c'est pas réversible. Après, il existe bien des rainbow tables qui permettent de casser des mdp "faibles" hashés en md5, masi c'est quand même beaucoup mieux qu'en clair
Edit : tu trouveras une implémentation de ce système (md5) dans mon appli Astres (cf ma signature). J'ai même hashé le mdp et le login cîté client, via une lib Javascript, comme ça, le login/mdp ne circule pas en clair entre le client et le serveur. Ca vaut pas du https, mais c'est déjà ça
Marsh Posté le 07-03-2012 à 12:29:39
Bon ça y est, SESSIONs bouclées, et pas sans mal
j'ai attaqué le md5, mais je n'arrive pas à trouver la syntaxe exacte pour l'insertion du mdp crypté dans ma BDD
c'est certainement une histoire de point, de guillements ou qq chose dans le genre
mysql_query("INSERT INTO `ACCES` (`log`, `pwd`, `mail`) VALUES ('$EDITlog', '$EDITpwd = md5($EDITpwd)', '$EDITmail');" );
mon champ pwd dans ma BDD est en "TEXTE", dois-je la passer en VARCHAR ?
Rufo -> je regarderais ce soir ton appli Astres, trop lourd pour le telech à mon taf
Marsh Posté le 07-03-2012 à 13:56:14
mysql_query("INSERT INTO `ACCES` (`log`, `pwd`, `mail`) VALUES ('$EDITlog', '".md5($EDITpwd)."', '$EDITmail');" );
Marsh Posté le 12-03-2012 à 14:53:09
YES YES YES ça fonctionne
je suis maintenant sur les injections SQL
j'ai testé quelques scripts et pour finir j'ai celui-ci :
<?php
session_start();
$_SESSION['id'] = $EDITlogin;
?>
<?
mysql_connect("xxxx", "xxxx", "xxxx" );
mysql_select_db("xxxx" );
$EDITlogin = mysql_real_escape_string($EDITlog);
$Resultat=mysql_query("SELECT * FROM `ACCES` WHERE `log` = '$EDITlogin' AND `pwd` = '".md5($EDITpwd)."'" );
if (mysql_numrows($Resultat) ==1)
{
je pense que ça fonctionne,
par contre ce qui me fait penser que qq chose cloche c'est que :
<?php
echo $_SESSION['id']; -> ne m'affiche rien
?>
<?php
echo $EDITlogin; -> affiche bien le log
?>
Marsh Posté le 12-03-2012 à 15:14:30
Si je repasse ma session en :
<?php
session_start();
$_SESSION['id'] = $EDITlog;
?>
<?php
echo $_SESSION['id'];
?>
affichage ok / navigation ok
Marsh Posté le 12-03-2012 à 15:39:26
La session, faudrait plutôt la créer si l'authentification fonctionne, donc récupérer les données depuis la requête SQL qui fait le SELECT.
$_SESSION['id'] = champ ID qui vient de la BD
Ensuite, dans tes pages, vers le début, tu feras un truc du genre
if ((isset($_SESSION['id'])) && (!empty($_SESSION['id'])))
{
// faire traitement quand t'es connecté
}
else
{
// traitement quand t'es pas connecté
}
Marsh Posté le 06-02-2012 à 16:20:11
Bonjour,
Voilà mon problème
J'ai un site web accessible seulement après identification log/pwd stockés sur une BDD)
jusque là tout fonctionne correctement
Ce qui bloque c'est qu'un fois l'authentification effectuée il est possible d'y accéder via les autre pages
Je m'explique : si un utilisateur enregistre en favoris une page quelconque de l'arborescence il peut ensuite s'y connecter à volonter sans passer par l'authentification
j'ai bien compris l'utilisation des Sessions sur tous les forums et tutos, mais je n'arrive pas à le mettre en place sur mon site.
Voici en gros l'architecture:
++++++++++++++++++++++++++++++++
index.php
- saisie des log/pwd
<form method="post" action="index1.php">
Login :<input type="text" name="EDITlog">
Mot de passe :<input type="password" name="EDITpwd">
<input type="submit" value="Valider">
+++++++++++++++++++++++++++++++
index1.php
<?php
include("misenpage.php" );
?>
puis l'autorisation d'accès:
<?
mysql_connect("xxxx", "xxxx", "xxxx" );
mysql_select_db("xxxx" );
$Resultat=mysql_query("SELECT * FROM `ACCES` WHERE `log` LIKE '$EDITlog' AND `pwd` LIKE '$EDITpwd'" );
if (mysql_numrows($Resultat) ==1)
{
?>
puis le corps du site ...
++++++++++++++++++++++++++++++++
misenpage.php (totalité de la page) :
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"><html>
<head>
<title>TITRE</title>
<link rel="stylesheet" type="text/css" href="CSS.CSS">
<style type="text/css">
</style>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<meta http-equiv="refresh" content="14400">
</head>
<body align=center>
<div id="fond">
<div id="corps">
<img src="image1.gif"/><img src="image2.gif"/>
++++++++++++++++++++++++++++++++
Et le reste du site du coup accessible directement
page1/page2/etc
avec à chaque fois l'include
je ne sais pas sur quelle page créer mes variables et où insérer session_start();
Bien évidament j'ai fais pas mal de tests mais tous non ok jusqu'à présent
si vous pouviez me mettre sur la voie svp
merci d'avance