Posez votre question Signaler

Problème: Double Pseudo (Sans Base de Donnée) [Résolu]

ClaudeDavy 14Messages postés 12 février 2007Date d'inscription - Dernière réponse le 17 mars 2007 à 16:54
Bonjour à toutes et é tous,
Je débute dans le PHP, mais j'avance bien. J'ai récemment cherché mon erreur dans un code. Mais je n'y arrive pas.
Je fais un petit site comme exercice pour que je comprenne mieux le code php avec les sessions.
Le problème s'est que je voudrais que les inscriptions ne soient pas en Double. Dans mon fichier Texte: Login.txt, quand je remet un même pseudo, il l'accepte et fait foirer tout mon code.
VOici mon code:
<?php
session_start();
?>

<html>
<head>
<title>Inscription</title>
<meta http-equiv="content-type" content="text/html; charset=iso-8859-1">
<link rel="stylesheet" type="text/css" href="../css/nouveau.css">
</head>
<body bgcolor="#ffcc99">

<?
echo "<h1>Nouveau Membre</h1>";
?>

<form action="../index.php" method="post">
<input type="submit" value="  Retour   "></form>
<form action="<?php echo $_SERVER['PHP_SELF']; ?>" method="post">
Votre prénom(obligatoire) :<br>
<input type="text" name="Nom"><br>
Mot de passe(obligatoire) :<br>
<input type="password" name="Mdp"><br><br>
Email(Pas obligatoire):<br>
<input type="text" name="email"><br><br>
<input type="submit" value="S'inscrire"></form>

<?php
if (isset($_POST["Nom"])||(isset($_POST["Mdp"])))
{
@$nom = $_POST['Nom'];
@$motdepasse = $_POST['Mdp'];
@$email = $_POST['email'];

$fichier="../Identification/login.txt";
$contenu=file($fichier);
	
// La variable commentaire est-elle définie ?		
if ($nom != "" && $motdepasse != "")
{	
foreach($contenu as $indice)
{
$indice = rtrim($indice);
$morceaux = explode(" ", $indice);

if($nom != $morceaux[0] && $email != $morceaux[2])
{
// On ouvre alors le fichier en lecture-écriture
$pointeur=fopen($fichier,"r+");
// On lit les anciennes données et on les stocke dans $anciennes
@$anciennes=fread($pointeur,filesize($fichier));
// Le lien de l'email
if ($email != "")
{
$membre = $nom." ".$motdepasse." ".$email." ";
}
else
{
$membre = $nom." ".$motdepasse." "."Inconnu"." ";
}
// On remet le curseur invisible au début du fichier
rewind($pointeur);
// Dans le fichier, on écrit le nouvel avis devant les anciens :
fputs($pointeur,"$membre\n$anciennes");
// On referme le fichier
fclose($pointeur);
}
else
echo "Email ou Pseudo déjà existants";
}
else
{
echo "Un ou Deux champ(s) vide(s) n'ont pas été rempli.";
}
}
?>

</body>
</html>
Lire la suite 

Problème: Double Pseudo (Sans Base de Donnée) »

9 réponses
Réponse
+0
moins plus
En gros tu souhaiterais tester si le pseudo existe déjà dans ton fichier ou non avant de l'y inscrire?



Ben
ClaudeDavy - 12 févr. 2007 à 13:59
Exactement. Il le test, mais pas correctement.
ClaudeDavy - 12 févr. 2007 à 14:01
Exactement. J'ai oublié de préciser que dans :
$morceaux[0] ( c'est le nom de 'lutilisateur dans mon fichier texte) et
$morceaux[2] (C'est le mot de passe dans mon fichier texte)
Ajouter un commentaire
Réponse
+0
moins plus
Si le modèle de la ligne est le suivant :

NOM MOTDEPASSE EMAIL\n

La ligne

$morceaux = explode(" ", $indice);

implique que $morceaux[0] = NOM, $morceaux[1] = MOTDEPASSE et $morceaux[2] = EMAIL

Peut être que le problème vient de là.

Autrement, bien que j'ai conscience qu'il s'agit d'un script de test, il vaut mieux prendre pour habitude de ne pas utilise l'espace comme séparateur, pour éviter les erreurs si l'utilisateur entre un espace dans son nom. Personellement j'utiliserai le "pipe" |

ex : NOM|MOTDEPASSE|EMAIL\n

avec un test pour supprimer les pipes éventuellement entrés par l'utilisateur, de cette manière :

$membre = str_replace("|", "",$nom) ."|". str_replace("|", "",$motdepasse). "|" . str_replace("|", "",$email) ."|";

Je sais pas expérience qu'il vaut mieux prendre l'habitude de ces petits détails, y compris pour les tests :)

Ben
Ajouter un commentaire
Réponse
+0
moins plus
Merci, ça m'a réglé le problème des pseudos doubles. Mais, il y a toujours un, mais. ^^

Il me met cette fois-ci le message qu'il y a déjà un double Pseudo ou Email, le problème c'est que même s'il le marque il l'a quand même inscris dans le fichier texte.

Deuxième problème c'est que si j'entre, maintenant un pseudo corecte etc... Il me le met à double Oo
Ajouter un commentaire
Réponse
+0
moins plus
Est-ce que vous pouvez voir ou bien donner votre avis ou vos codes qui vous ont servis pour ce genre de problèmes ?

Le problème vient de la boucle "Foreach" mal placé? && ? || ? Je ne sais pas. :/
Ajouter un commentaire
Réponse
+0
moins plus
Au niveau de votre test je pense qu'il y a un soucis.

Si j'avais à faire un tel script, je testerai d'abord le nouveau pseudo/email contre toutes les lignes du fichier avant de penser à l'inscrire dedans.

En gros :

$doublon = false;

foreach($contenu as $indice){
//Pour chaque ligne
$indice = rtrim($indice);
$morceaux = explode(" ", $indice);

//On teste si le pseudo ou email est équivalent

//Si oui, on passe la variable $doublon à true et on sort de la boucle
if($nom == $morceaux[0] || $email == $morceaux[2]) {
$doublon = true;
break;
}

//Si non, on continue à la ligne suivante
else continue;
}

//Ici on verifie si le pseudo/email a été trouvé dans le fichier
if($doublon){
//Insérer le code correspondant à la présence d'un doublon
}
else {
//on ajoute le pseudo/mot de passe au fichier
$fichier="../Identification/login.txt";
$fp = fopen($fichier, "a"); //j'ouvre en mode append qui place le pointeur à la fin
if($fp) fwrite($fp, $membre . "\n");
fclose($fp);
}


A noter que dans le cas de mon code, les doublons d'email seront interdits au même titre que les doublons de pseudo, à savoir qu'un même pseudo avec une adresse différente ne sera pas accepté et une même adresse avec un pseudo différent ne sera pas acceptée non plus.


Dites moi si ça vous convient :)

Ben
Ajouter un commentaire
Réponse
+0
moins plus
ça me convient tellement parfaitement que je n'arrive pas à décrire ma joie !

Je vous remercie infiniment ! Merci ! Merci !
Ajouter un commentaire
Réponse
+0
moins plus
je marrive pa a me créer un pseudo alors aider moi svp
Ajouter un commentaire
Ce document intitulé « Problème: Double Pseudo (Sans Base de Donnée) » issu de CommentCaMarche (www.commentcamarche.net) est mis à disposition sous les termes de la licence Creative Commons. Vous pouvez copier, modifier des copies de cette page, dans les conditions fixées par la licence, tant que cette note apparaît clairement.
Dossier à la une
5 extensions si vous voulez revenir à l'ancien Facebook