[PHP] probleme méthode post
lord seregon
Messages postés
61
Statut
Membre
-
lord seregon Messages postés 61 Statut Membre -
lord seregon Messages postés 61 Statut Membre -
Bonjour,
Je suis en train de codez un site PHP, mais j'ai un problème sur la connexion je n'arrive pas à récupérer mes champs en méthode POST, alors qu'en méthode GET il n'y a aucun problème !
Voici mon code :
Je suis en train de codez un site PHP, mais j'ai un problème sur la connexion je n'arrive pas à récupérer mes champs en méthode POST, alors qu'en méthode GET il n'y a aucun problème !
Voici mon code :
If(!isset($_SESSION['utilisateur']) && !isset($_POST['Nom']))
{
// on affiche le formulaire
echo '<div id="connexion">';
echo "<!-- formulaire de connexion -->";
echo '<form name="connect" method=POST Action = '.$page.'>';
?>
<!-- Champs pour le Login -->
Login : <br />
<input type="text" name="Nom" value="" /><br />
<!-- Champs pour le mot de passe -->
Mot de Passe :<br />
<input type="password" name="mdp" value="" /><br />
<!-- Validation-->
<input type="submit" value="Envoyer" />
// on referme les balise
</form> </div>
<?php }
A voir également:
- [PHP] probleme méthode post
- Easy php - Télécharger - Divers Web & Internet
- Brouillon post instagram - Guide
- Post it windows - Télécharger - Agendas & Calendriers
- Code post - Télécharger - Vie quotidienne
- Expert php pinterest - Télécharger - Langages
6 réponses
Bonjour,
Dans la déclaration de ton formulaire, met des guillemets autour POST :
echo '<form name="connect" method="POST" Action = '.$page.'>';
Je pense que ça devrait normalement régler ton problème...
Dans la déclaration de ton formulaire, met des guillemets autour POST :
echo '<form name="connect" method="POST" Action = '.$page.'>';
Je pense que ça devrait normalement régler ton problème...
Bonjour,
Avec les guillemets, c'est quand même plus propre, y compris autour de $page.
Quant à ton problème, peux-tu nous montrer de quelle façon tu récupères ces variables dans $page ?
Xavier
Avec les guillemets, c'est quand même plus propre, y compris autour de $page.
Quant à ton problème, peux-tu nous montrer de quelle façon tu récupères ces variables dans $page ?
Xavier
J'ai essayer ta méthode bob633, mais pas plus de résultat, Reivax962 même en les affichant avec un echo simple, ça ne fonctionne pas, une fois que je pourrais les affiché je pourrait me débrouiller pour la suite.
Ce que je n'est pas préciser c'est que j'ai mis sa dans une fonction que j'inclus dans toute mes pages, c'est la qu'intervient ma variable $page : c'est l'adresse de ma page courante
Je viens d'essayer en récupérant ma variable dans ma page 'principale', celle qui est affiché dans laquelle j'appelle ma fonction connexion, et sa fonctionne sa veut dire que je ne peut pas la récupérer dans une fonction ?
Ce que je n'est pas préciser c'est que j'ai mis sa dans une fonction que j'inclus dans toute mes pages, c'est la qu'intervient ma variable $page : c'est l'adresse de ma page courante
Je viens d'essayer en récupérant ma variable dans ma page 'principale', celle qui est affiché dans laquelle j'appelle ma fonction connexion, et sa fonctionne sa veut dire que je ne peut pas la récupérer dans une fonction ?
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Voila le code, c'est la page index, depuis mon dernier message il a évoluer.
Et voila mes fonctions :
<!DOCTYPE html>
<html>
<?php
session_start();
// on se connecte à la BDD
include('connexion_db.php');
$connexion = connexion();
?>
<head>
<title>Covoiturer sur Fleyriat</title>
<link rel="stylesheet" type="text/css" href="MonCss.css">
</head>
<body>
<p id="bandeau">
Mon Bandeau
<?php
include('Connexion_champs.php');
If(!isset($_SESSION['utilisateur']) && !isset($_POST['login']))
{
connect("Index.php");
}
else
{
If(isset($_POST['login']) && !isset($_SESSION['utilisateur']))
{
connecting($_POST['login'], $_POST['pw'], $connexion, "Index.php");
}
else
{
connected($_SESSION['nom']);
}
}
?>
</p>
<div id="menu">
<?php
include("menu.php");
?>
</div>
<div id="corps">
<h1> Bienvenue sur le site de covoiturage </h1>
<?php
// on compte le nombre d'utilisateur
$resultat = mysql_query("Select count(Util_Code) from utilisateur;", $connexion);
// si il y a une r?ponse, on l'affiche
if($ligne = mysql_fetch_array($resultat))
{
echo ("Il y a ".$ligne[0]." utilisateurs enregistr?s.");
echo ("<br />");
}
$resultat = mysql_query("Select count(T_Code) from trajet;", $connexion);
if($ligne = mysql_fetch_array($resultat))
{
echo("Il y a ".$ligne[0]." trajets ajout?s.");
echo ("<br />");
}
?>
</div>
</body>
</html>
Et voila mes fonctions :
<?php
// fonction pour afficher le formulaire de connexion
function connect($page)
{
// alors on affiche le formulaire
echo '<div id="connexion">';
echo "<!-- formulaire de connexion -->";
echo "<form name=\"connect\" Action =".$page." method=\"POST\" >";
?>
<!-- Champs pour le Login -->
Login : <br />
<input type="text" name="login" value="" /><br />
<!-- Champs pour le mot de passe -->
Mot de Passe :<br />
<input type="password" name="pw" value="" /><br />
<!-- Validation-->
<input type="submit" value="Envoyer" />
<?php
// on referme les balise
echo "</form> </div>";
}
// sinon
Function connecting($login, $pw, $connexion,$page)
{
//si on essaye de se connecter
// on assgigne la requete
$requete="Select Util_Code, Util_Nom FROM Utilisateur where util_nom = ".$login." AND util_mdp = ".md5($pw).";";
// on execute la requete
$resultat=mysql_query($requete, $connexion);
// si il y a des lignes retourné
if(mysql_num_rows($resultat)<>false)
{
// on lit les resultat
$ligne=mysql_fetch_array($resultat);
// on récupère le nom et le numero de l'utilisateur dans la variable session
$_SESSION["utilisateur"]=$ligne[0];
$_SESSION["Nom"]=$ligne[1];
// et on affiche un message de bienvenue
echo "Bienvenue ".$_SESSION['nom'];
}
else
{
// si il y a une erreur on affiche un message
// puis on se recharge la page
header('location:'.$page);
}
}
Function connected($Nom)
{
// si on est connecté on affiche un message de bienvenue
echo "Bienvenue ".$Nom;
}
?>
OK, alors j'ai deux remarques :
1 - attention, ton code est sujet aux attaques par injection SQL, car ut utilise directement $_POST['login'] dans ta requête SQL. Pour s'en prémunir, tu dois y appliquer la fonction mysql_real_escape_string() https://www.php.net/manual/fr/function.mysql-real-escape-string.php
2 - je crois que j'ai compris d'où vient le problème.
C'est vraiment idiot : il y a une espace entre Action et le = : il n'en faut pas !
Cela devient donc :
echo "<form name='connect' action='$page' method='POST' >";
Xavier
1 - attention, ton code est sujet aux attaques par injection SQL, car ut utilise directement $_POST['login'] dans ta requête SQL. Pour s'en prémunir, tu dois y appliquer la fonction mysql_real_escape_string() https://www.php.net/manual/fr/function.mysql-real-escape-string.php
2 - je crois que j'ai compris d'où vient le problème.
C'est vraiment idiot : il y a une espace entre Action et le = : il n'en faut pas !
Cela devient donc :
echo "<form name='connect' action='$page' method='POST' >";
Xavier
Met aussi des guillemets autour de $page : "'.$page.'"
Et ça serait en effet pas mal de voir le code $page.
D'ailleurs y'a quoi dans ta variable $page?