Zum Inhalt springen
View in the app

A better way to browse. Learn more.

Fachinformatiker.de

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

$_SESSION['lala'] kann nicht auf neuer Seite abgefragt werden

Empfohlene Antworten

Veröffentlicht

Hallo!

Ich Starte auf der Indexseite einer HP eine Session. Dann setzte ich

$_SESSION['lala'] = 11;

Dann rufe ich von dieser seite mit nem Link ne neue Seite auf:

<a href="./seite.php" target"_self">seite</a>

auf dieser Seite steht mir $_SESSION['lala'] nicht mehr zur Verfügung, obwohl das doch eigentlich der Sinn dieser Variablen ist. Ist die Session da nicht mehr gültig? Wichtig ist, dass ich die Variable nicht an die URL hänge. Oder muss ich dazu die Session ID mit übergeben?

Danke

Volki

Zuerst einmal muss, wenn du Sessions verwendest, am Anfang der Datei (vor jeglicher Ausgabe)

session_start();

stehen.

Dann kannst du nur auf die Variablen zugreifen, wenn du sie auch mit der URL übergibst.

Das ganze sieht dann z. B. so aus:

-> formular (index.php):

<?php
session_name("meine_session");
session_start();
?>
<html>
<head>
<title>Test</title>
</head>
<body>
<form action="<?php echo 'admin.php?'.session_name().'='.session_id(); ?>" method="post">
<input type="text" name="name" /><br />
<input type="password" name="passwort" /><br />
<input type="submit" name="submit" value="einloggen" />
</form>
</body>
</html>[/php]

-> admin.php:

[php]<?php
session_name("meine_session");
session_start();
mysql_connect("servername","username","passwort");
mysql_select_db("datenbankname");
$sql = "select Name, Password from userdata where Name = \"".$_POST['name']."\" AND Password = \"".$_POST['passwort']."\"";
$record = mysql_query($sql);
if(!$record) echo "Fehler: falscher Username oder falsches Passwort!<br /><a href=logout.php?".session_name()."=".session_id().">zurück</a>";
else
{
$_SESSION['name'] = $_POST['name'];
$_SESSION['passwort'] = $_POST['passwort'];
echo "Name: ".$_SESSION['name']."<br />";
echo "Passwort: ".$_SESSION['passwort'];
echo "<br /><a href=logout.php?".session_name()."=".session_id().">logout</a>";
}
?>

... und schon hat man ein kleines Login-System mit einer MySQL-Datenbank gebastelt. Was natürlich noch fehlt, ist eine Verschlüsselung der Passwörter.

Achso, die logout.php:

<?php
session_start();
session_destroy();
header("Location: index.php");
?>[/php]

Archiv

Dieses Thema wurde archiviert und kann nicht mehr beantwortet werden.

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.