Avatar billede ze-men Nybegynder
06. januar 2007 - 17:04 Der er 1 kommentar og
1 løsning

Overførelse af session til andre php-sider

Jeg har lavet et log-in system, hvor man som bruger kan logge ind. Oplysningerne ses og kontrolleres fra en MySQL-database. Er brugernavn og password tastet rgtigt, så sendes man videre til index.php. Men problemet er at den ikke beholder oplysningerne for den indtastede session ved log-in. Så når jeg så laver en connection til MySql-databasen fra index-siden, for at vise "Velkommen >brugernavn<", så vises der intet. Jeg skal derfor have 'gemt' session'en, så jeg kan hente det frem. Bedst ville være om det var bruger-ID'et der blev gemt, da det er primærnøglen.

Jeg har lavet siden i Dreamweaver, så det er programmet der har sat koderne.

Håber meget nogen kan hjælpe.

Selve log-in funktionen findes øverst på siden og ser sådan ud:

<?php require_once('../Connections/tvduno.php'); ?>
<?php
// *** Validate request to login to this site.
session_start();

$loginFormAction = $_SERVER['PHP_SELF'];
if (isset($accesscheck)) {
  $GLOBALS['PrevUrl'] = $accesscheck;
  session_register('PrevUrl');
}

if (isset($_POST['brugernavn'])) {
  $loginUsername=$_POST['brugernavn'];
  $password=$_POST['password'];
  $MM_fldUserAuthorization = "status";
  $MM_redirectLoginSuccess = "index.php";
  $MM_redirectLoginFailed = "login_fejl.php";
  $MM_redirecttoReferrer = false;
  mysql_select_db($database_tvduno, $tvduno);
     
  $LoginRS__query=sprintf("SELECT brugernavn, password, status, brugerid FROM fan_brugere WHERE brugernavn='%s' AND password='%s'",
  get_magic_quotes_gpc() ? $loginUsername : addslashes($loginUsername), get_magic_quotes_gpc() ? $password : addslashes($password));
 
  $LoginRS = mysql_query($LoginRS__query, $tvduno) or die(mysql_error());
  $loginFoundUser = mysql_num_rows($LoginRS);
  if ($loginFoundUser) {
   
    $loginStrGroup  = mysql_result($LoginRS,0,'status');
   
    //declare two session variables and assign them
    $GLOBALS['MM_Username'] = $loginUsername;
    $GLOBALS['MM_UserGroup'] = $loginStrGroup;         

    //register the session variables
    session_register("MM_Username");
    session_register("MM_UserGroup");

    if (isset($_SESSION['PrevUrl']) && false) {
      $MM_redirectLoginSuccess = $_SESSION['PrevUrl'];   
    }
    header("Location: " . $MM_redirectLoginSuccess );
  }
  else {
    header("Location: ". $MM_redirectLoginFailed );
  }
}
?>
<?php require_once('../Connections/tvduno.php'); ?>
Avatar billede showsource Seniormester
06. januar 2007 - 19:25 #1
Well, ville nok droppe programmet til at lave PHP kode.

Og du har selvf. session_start() på dine andre sider?
Avatar billede ze-men Nybegynder
07. januar 2007 - 09:44 #2
Hey, ja. Jeg har session_start() på alle mine andre sider. Men fandt ud af det alligevel, ved selv at lave koden:-)

- tak ellers for svaret.
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
IT-kurser om Microsoft 365, sikkerhed, personlig vækst, udvikling, digital markedsføring, grafisk design, SAP og forretningsanalyse.

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester