IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage PHP Discussion :

Session sans login!


Sujet :

Langage PHP

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 12
    Points : 7
    Points
    7
    Par défaut Session sans login!
    Bonjour,

    Je poste mon problème ds la catégorie session, mais il ne s'agit pas vraiment d'un problème avec login/mdp.

    Un lien vaut mieux que beaucoup de lignes :

    http://enigmeschristophe.free.fr/eni...es/enigme1.php

    Je cherche à comprendre comment est faite cette page!

    Pour mieux vous expliquer, il s'agit d'un site d'énigmes ou on passe à la page suivante en tapant un mot de passe (la réponse à l'enigme courante)

    Son code est protégé.

    Qui plus est, le nom de la page n°2 est la réponse à l'énigme 1.
    Il ne doit donc pas apparaitre dans le code!

    Comment fait il ca?

    Merci pour vos réponses,
    salutations

  2. #2
    Membre averti
    Homme Profil pro
    Consultant ERP
    Inscrit en
    Mai 2006
    Messages
    257
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Consultant ERP
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2006
    Messages : 257
    Points : 318
    Points
    318
    Par défaut
    Bonjour, je crois qu'il poste la valeur par un formulaire genre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    <form action="page2" method="post">
    <input type="text" name="reponse"/>Entrez la réponse.
    </form>
    Et dans la page 2 tu fais
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Vous avez choisi cette réponse <?php echo $_POST['reponse']; ?>
    Tu ferais mieux de lire des cours dans la rubrique php sur les formulaires et les sessions.
    Et bonne chance.

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 12
    Points : 7
    Points
    7
    Par défaut
    Non, en fait ce qui est embêtant, c'est que dans ta solution, la destination du php (page2) est affichée ds le code source, donc rien n'empêche le malotru de regarder dans le code source, puis de taper cette réponse dans la saisie de texte!

  4. #4
    Membre émérite Avatar de Djakisback
    Profil pro
    Inscrit en
    Février 2005
    Messages
    2 023
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 2 023
    Points : 2 273
    Points
    2 273
    Par défaut
    Salut,
    il faut que tu fasses une redirection :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    if(isset($_POST['reponse']) && ($_POST['reponse'] == "enigme2" || $_POST['reponse'] == "enigme 2"))
     header("Location: enigme2.php");

  5. #5
    Membre averti
    Homme Profil pro
    Consultant ERP
    Inscrit en
    Mai 2006
    Messages
    257
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Consultant ERP
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2006
    Messages : 257
    Points : 318
    Points
    318
    Par défaut
    Non, en fait ce qui est embêtant, c'est que dans ta solution, la destination du php (page2) est affichée ds le code source, donc rien n'empêche le malotru de regarder dans le code source, puis de taper cette réponse dans la saisie de texte!
    On quoi ça peut lui être utile de connaitre la page de destination?! puisque les informations ne paraisseront dans la deuxième page que s'ils sont envoyé par la méthode POST.

  6. #6
    Membre émérite Avatar de Djakisback
    Profil pro
    Inscrit en
    Février 2005
    Messages
    2 023
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 2 023
    Points : 2 273
    Points
    2 273
    Par défaut
    tu fais un clic droit et t'as la solution de l'énigme, c'est un peu bidon pour un site d'énigmes ^^

  7. #7
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    <form name=formulaire method=post action=enigme1.php>Saisissez une réponse :
    Le formulaire redirige sur la page elle-même, donc la solution de l'enigme doit se trouver dans le même script php que l'enigme proprement dite. MAIS ce que voit un utilisateur c'est le code interprété en html et non le code php.

    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    <form action="" method="post">
      Tapez un mot :<input type="text" name="champ">
      <input type="submit" name="Envoi">
    </form>
    <?php
    $champ = (isset($_POST['champ'])?$_POST['champ']:'';
    if ($champ == 'chaussette')
    {
      echo 'Bravo vous avez tapé le bon mot';
    }
    else
    {
     echo 'Vous devez taper quelque chose d\'autre';
    }
    ?>
    Le code ci-dessus n'écrira "Vous avez tapé le bon mot" que si le mot tapé est chaussette.
    Mais tout ce que verra l'utilisateur en regardant le code source (tant qu'il n'aura pas tapé chaussette) c'est le code html suivant :
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    <form action="" method="post">
      Tapez un mot :<input type="text" name="champ">
      <input type="submit" name="Envoi">
    </form>
    Vous devez taper quelque chose d'autre

    Est-ce clair ?

  8. #8
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 12
    Points : 7
    Points
    7
    Par défaut
    C'est parfaitement clair, merci.

    J'ai donc testé un code en me servant du votre pour modele.
    Je l'ai envoyé sur le serveur, mais pas moyen, le code a l'air parfait, cependant la redirection quand le mot de passe est bon ne fonctionne pas.

    Pourriez vous me dire si mon code est ok?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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
    <?php
     
    define('LE_PASSWORD','mdp');
     
    // On redirige si le password n'est pas transmis ou s'il est mauvais (différent de la valeur de la constant LE_PASSWORD)
    if(empty($_POST['texte']) || ($_POST['texte'] !== LE_PASSWORD)) {
        header(
     "Status: 301 Moved Permanently", false, 301);
    header(
     "Location: http://www.faux.com");
        exit;
    }
    else
    {
    header(
     "Status: 301 Moved Permanently", false, 301);
    header(
     "Location: http://www.juste.com");
        exit;
    ?>  
    <html>
    <head>
      <meta content="text/html; charset=ISO-8859-1"
     http-equiv="content-type">
      <title></title>
    </head>
    <body>
    <form method="post" action="depart.php" name="formu"><input
     name="texte">&nbsp;<input name="envoyer"
     value="Valider la réponse" type="submit"></form>
    </body>
    </html>

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Session formulaires sans login
    Par xunil2003 dans le forum Langage
    Réponses: 21
    Dernier message: 11/07/2012, 10h59
  2. [Débutant]infos ds session sans cookie ? url rewriting ?
    Par Satanas_et_diabolo dans le forum ASP
    Réponses: 8
    Dernier message: 10/10/2006, 17h13
  3. [Struts][Tomcat] Session sans cookies
    Par tuxor dans le forum Struts 1
    Réponses: 2
    Dernier message: 13/01/2006, 12h06
  4. Entrer dans une session sans devoir cliquer sur ok au demarr
    Par beegees dans le forum Windows Serveur
    Réponses: 3
    Dernier message: 22/12/2005, 10h50
  5. [debutant][jsp]Passage d'entier avec une session sans cookie
    Par o151181 dans le forum Servlets/JSP
    Réponses: 5
    Dernier message: 04/02/2004, 18h22

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo