session variablen werden auf der nächsten seite gelöscht

Einklappen
X
 
  • Filter
  • Zeit
  • Anzeigen
Alles löschen
neue Beiträge

  • session variablen werden auf der nächsten seite gelöscht

    Ich habe ein Code geschrieben, in dem Code sind Variablen die ich mit session markiere.
    Aber diese werden auf der nächsten seite gelöscht, deswegen hat man doch session variablen.
    Ich denke mal ich mache irgendwas falsch, vielleicht könnt ihr den Fehler ja entdecken.
    PHP-Code:
    <?php
    session_start
    ();
    echo 
    "Sie wurden Erfolgreich eingeloggt."
    ?>
    <form method="POST" action="kampf.php">
    <b>Angreifen:</b><br>
    <br>
    <select name="angriffsauswahl">
    <option value="sangriff">Schlag</option>
    <option value="tangriff">Tritt</option>
    </select>
    <input type=submit name=submit value="Angreifen!">
    </form>
    <?php
    $leben
    50;
    $sangriff 10;
    $tangriff 15;
    $gleben 100;
    $_SESSION['sangriff'] = "10";
    $_SESSION['tangriff'] = "15";
    $_SESSION['gleben'] = "10000";
    if(!
    $_POST["angriffsauswahl"])
    {
    if (
    $_POST["angriffsauswahl"] == "sangriff"$endleben $gleben $sangriff;
    else 
    $endleben $gleben $tangriff;
     echo 
    "Leben: $leben
    <br/>
    Schlagangriff: 
    $sangriff Schaden
    <br/>
    Trittangriff: 
    $tangriff Schaden
    <br/>

  • #2
    Hallo,

    hast du in der kampf.php auch session_start() aufgerufen?

    Gruß,

    Amica
    [COLOR="DarkSlateGray"]Hast du die [COLOR="DarkSlateGray"]Grundlagen zur Fehlersuche[/color] gelesen? Hast du Code-Tags benutzt?
    Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
    Super, danke!
    [/COLOR]

    Kommentar


    • #3
      kampf.php

      das ist kampf.php.
      Vielleicht liegt das daran das der link zu der gleichen seite führt.
      Kann das sein?

      Kommentar


      • #4
        Nein, wenn das die kampf.php ist, liegt es nur daran, dass du mit der Session nichts sinnvolles anstellst. Du schreibst Startwerte rein und das immer wieder. Die Ergebnisse der Angriffe werden aber nicht in der Session akkumuliert, sondern in irgendweclhen sinnlosen Variablen, die dann nicht mehr benutzt werden.
        [COLOR="DarkSlateGray"]Hast du die [COLOR="DarkSlateGray"]Grundlagen zur Fehlersuche[/color] gelesen? Hast du Code-Tags benutzt?
        Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
        Super, danke!
        [/COLOR]

        Kommentar


        • #5
          also muss ich das endleben mit sessions speichern

          außerdem soll man den gegner immer wieder angreifen können.
          Zuletzt geändert von AmicaNoctis; 02.01.2011, 18:00.

          Kommentar


          • #6
            Genau.

            Übrigens musst du nicht jeden Satz in einen neuen Beitrag schreiben. Wenn du was vergessen hast, kannst du deine Postings auch nachträglich noch
            [COLOR="DarkSlateGray"]Hast du die [COLOR="DarkSlateGray"]Grundlagen zur Fehlersuche[/color] gelesen? Hast du Code-Tags benutzt?
            Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
            Super, danke!
            [/COLOR]

            Kommentar


            • #7
              geändert

              OK, das habe ich jetzt gemacht. Aber es hat nicht ganz funktioniert.
              Es ist so, man kann ja dann den Angriff auswählen. Und dann drückt man auf angreifen. Dann verschwinden die ganzen Werte( schaden leben und gegnerisches leben ). Und man kann nur noch schlag oder tritt wählen.
              Und wenn man dann angreift sieht man jeweils das aktuelle gegnerische leben nicht und wahrscheinlich verändert sich das Leben auch nicht.
              Vielleicht ist immer noch was falsch:
              PHP-Code:
              <?php
              session_start
              ();
              echo 
              "Sie wurden erfolgreich eingeloggt."
              ?>
              <form method="POST" action="kampf.php">
              <b>Angreifen:</b><br>
              <br>
              <select name="angriffsauswahl">
              <option value="sangriff">Schlag</option>
              <option value="tangriff">Tritt</option>
              </select>
              <input type=submit name=submit value="Angreifen!">
              </form>
              <?php
              $leben
              50;
              $sangriff 10;
              $tangriff 15;
              $gleben 100;
              $_SESSION['endleben'];
              if(!
              $_POST["angriffsauswahl"])
              {
              if (
              $_POST["angriffsauswahl"] == "sangriff"$endleben $gleben $sangriff;
              else 
              $endleben $gleben $tangriff;
               echo 
              "Leben: $leben
              <br/>
              Schlagangriff: 
              $sangriff Schaden
              <br/>
              Trittangriff: 
              $tangriff Schaden
              <br/>
              Dein Gegner hat noch 
              $endleben Leben";
              }
              ?>

              Kommentar


              • #8
                Es muss so ablaufen:

                Wenn noch nichts in der Session steht (isset), dann schreibst du den Startwert rein. Andernfalls verarbeitest du die Eingabe und aktualisierst den Wert in der Session:

                PHP-Code:
                $_SESSION["endleben"] = ...; 
                [COLOR="DarkSlateGray"]Hast du die [COLOR="DarkSlateGray"]Grundlagen zur Fehlersuche[/color] gelesen? Hast du Code-Tags benutzt?
                Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
                Super, danke!
                [/COLOR]

                Kommentar


                • #9
                  So?
                  PHP-Code:
                  <?php
                  session_start
                  ();
                  echo 
                  "Sie wurden erfolgreich eingeloggt."
                  ?>
                  <form method="POST" action="kampf.php">
                  <b>Angreifen:</b><br>
                  <br>
                  <select name="angriffsauswahl">
                  <option value="sangriff">Schlag</option>
                  <option value="tangriff">Tritt</option>
                  </select>
                  <input type=submit name=submit value="Angreifen!">
                  </form>
                  <?php
                  $leben
                  50;
                  $sangriff 10;
                  $tangriff 15;
                  $endleben 100;
                  $_SESSION['endleben'] = 100;
                  if(!
                  $_POST["angriffsauswahl"])
                  {
                  if (
                  $_POST["angriffsauswahl"] == "sangriff"$endleben $sangriff;
                  else 
                  $endleben $tangriff;
                   echo 
                  "Leben: $leben
                  <br/>
                  Schlagangriff: 
                  $sangriff Schaden
                  <br/>
                  Trittangriff: 
                  $tangriff Schaden
                  <br/>
                  Dein Gegner hat noch 
                  $endleben Leben";
                  }
                  ?>

                  Kommentar


                  • #10
                    Nein, so nicht. Vielleicht solltest du doch mit den Grundlagen anfangen, etwas das PHP Handbuch lesen und Tutorials durcharbeiten. Ich hab dir ja schon fast die Lösung genannt. Wenn ich weiter ginge, würde ich dein "Noch so ein Browserspiel"-Projekt selbst schreiben. Sorry
                    [COLOR="DarkSlateGray"]Hast du die [COLOR="DarkSlateGray"]Grundlagen zur Fehlersuche[/color] gelesen? Hast du Code-Tags benutzt?
                    Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
                    Super, danke!
                    [/COLOR]

                    Kommentar


                    • #11
                      hab ich

                      das habe ich schon, und zwar das zweite mal.
                      In den Session Tutorials wird einem nichts erklärt, wo man mit solchen Problemen klar kommt oder überhaupt etwas anderes als ein Login machen kann.
                      Ich hatte mir gedacht wenn ich es an dem Beispiel lerne kriege ich es auch für andere Sachen hin.

                      Kommentar


                      • #12
                        Dein Problem ist diese Zeile:

                        Zitat von slowbreak Beitrag anzeigen
                        PHP-Code:
                        $_SESSION['endleben'] = 100
                        Dort setzt du immer und bedingungslos den Wert fest und zwar immer wieder bei jedem Aufruf. Das macht keinen Sinn. Arbeite mit Fallunterscheidung (if ... else).
                        [COLOR="DarkSlateGray"]Hast du die [COLOR="DarkSlateGray"]Grundlagen zur Fehlersuche[/color] gelesen? Hast du Code-Tags benutzt?
                        Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
                        Super, danke!
                        [/COLOR]

                        Kommentar


                        • #13
                          ok

                          ok das beanmtwortet einiges ich werde es dann mal so oft versuchen bis es irgendwann irgendwie funktioniert. xD
                          Danke für deine Hilfe.

                          Kommentar


                          • #14
                            So ich sitze daran jetzt seit 4 Stunden und es klappt nicht.
                            Ich habe alles probiert und auch immer wieder nachgeschaut wie es gehen soll, bin dabei auch auf die Fallunterscheidungen angegangen.
                            Ich bin so weit gekommen:
                            PHP-Code:
                            <?php
                            session_start
                            ();
                            echo 
                            "Sie wurden erfolgreich eingeloggt."
                            ?>
                            <style type="text/css">

                            BODY {background-color:#239333; color:#FFFFFF;}
                            TD {border:1px solid #666666;}

                            </style>
                            <form method="POST" action="kampf.php">
                            <b>Angreifen:</b><br>
                            <br>
                            <select name="angriffsauswahl">
                            <option value="sangriff">Schlag</option>
                            <option value="tangriff">Tritt</option>
                            </select>
                            <input type=submit name=submit value="Angreifen!">
                            </form>
                            <?php
                            $leben
                            50;
                            $sangriff 10;
                            $tangriff 15;
                            $_maxleben =100;
                            $endleben = (int)$_SESSION['endleben'] = 100;
                            if(!
                            $_POST["angriffsauswahl"] == "sangriff")
                             {
                             
                            $endleben $sangriff;
                             }
                            if(!
                            $_POST["angriffsauswahl"] == "tangriff")
                             {
                             
                            $endleben $tangriff;
                             }
                             echo 
                            "Der Gegner hat noch $endleben/$_maxleben Leben"
                            ?>
                            Ihr habt mir ja gesagt das der wert endleben sich nicht ändern lässt.
                            Jetzt mache ich mir Gedanken darüber wie ein Code aussieht der sagt:
                            Dieser Wert ist veränderbar.
                            Mit welchen Befehlen könnte man das machen?

                            Kommentar


                            • #15
                              Schau dir doch dein Script mal an. Jedesmal wenn die kampf.php aufgerufen wird schreibst du in die Session den Wert "endleben" mit 100.
                              PHP-Code:
                              $endleben = (int)$_SESSION['endleben'] = 100
                              Dann wird eine Aktin ausgeführt und es werden temporär Punkte vom "endleben" abgezogen. Diese Werte werden aber nicht in die Session geschrieben oder ähnliches. Das einzige das passiert ist das jedesmal bei Aufruf der wert endleben auf 100 gesetzt wird.

                              Prüfe vorher ob schon ein Session wert "endleben" exisitert. Wenn nicht dann setzt diesen auf 100, wenn nicht dann mache nichts. Wenn eine Aktion ausgeführt wird hole den "endleben" wert aus der Session, ziehe von ihm die Punkte ab und schreibe anschließend den neuen Wert wieder in die Session in dem du "endleben" dann auf den neuen Wert setzt.

                              Kommentar

                              Lädt...
                              X