2014-11-08 85 views
0

我在存儲$ _SESSION變量時遇到了一個問題,我在PHP有點新,我喜歡它以達到我當前的知識水平。

首先我creds:

的Win 7專業版64 PHP 5 遠程服務器(不知道其配置的)

那麼,我試圖做的是建立一個登錄頁面,其中包含一個硬編碼用於測試目的的用戶名和密碼。

我想在後續頁面上顯示用戶名以確認它。

的login.php

<?php session_start();?> 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 

<html xmlns="http://www.w3.org/1999/xhtml"> 

<head > 
<title>Login</title> 

<link rel="stylesheet" href="style.css" type="text/css" media="screen" /> 
<meta http-equiv="content-type" content="text/html; charset=utf-8" /> 
<meta http-equiv="content-language" content="en-gb" /> 

<script type="text/javascript"> 
    // Perform Client side validation of Username and Password 
    function redirect() { 
     var username = document.getElementById("username"); 
     var password = (document.getElementById("password")); 

     if (!username.value == " ") { 
      if (!password.value == " ") { 
       if (username.value == "aknight") { 
        if (password.value == "00226291") { 
         window.location = "Home.php"; 
         exit(); 
        } else 
         alert("Username or Password Invalid"); 
       } 
      } else 
       alert("Password is required"); 
     } else 
      alert("Username is required"); 
    } 
</script> 
</head> 

<body> 
<div id="header"> 
<h1>Product Order System</h1> 
<br/> 
<h2>The most expensive crap youll ever find...</h2> 
</div> 

<div id="content"> 
<?php 

if ($_SERVER['REQUEST_METHOD'] == 'POST'){ 

$_SESSION['username'] = $_POST['username']; 

}else{ 
?> 

<form action="" method="POST"> 
<fieldset> 
<legend>Login Information</legend> 
<p> 
<label for="Username">Username:</label> 
<input type="text" name="username" id="username" /> 
</p> 
<p> 
<label for="Password">Password:</label> 
<input type="password" name="password" id="password" /> 
</p> 
<p> 
<input type="button" name="login" value="Login" onclick="redirect();"/> 
<input type="button" name="cancel" value="Cancel" /> 
</fieldset> 
</form> 
<?php } 

    include ('includes/footer.html'); 
?> 

home.php

<?php 
session_start(); 
$page_title = 'Home'; 
include ('includes/header.php'); 
if(isset($_SESSION['username'])) { $name = $_SESSION['username'];}else{echo "<p>error</p>";} 
echo "<h3>Welcome ".$name."!</h3>" ; 
?> 

我試圖打印出$_SESSION值,他們都上來了空。

產生這樣的結果

<?php 
    echo "<pre>".print_r($_SESSION)."</pre>"; 
?> 

Array { 
    [username] => 
} 

請不要介意JS,這是學齡前客戶端驗證只是向前邁進。

任何幫助將不勝感激。

回答

0

給你的登錄表單一個名字,然後在你的JavaScript驗證函數中,而不是window.location,做一個document.forms ['yourformname']。submit()。

+0

我會盡量避免在JS使用的形式,但這是有道理的,是一個很大的視線。 – codeMonkey 2014-11-08 19:00:29

0

我認爲你的Javascript驗證實際上是什麼導致問題。 您正在使用POST請求在Login.php中設置會話變量,但是沒有POST實際上被髮送到Login.php,因爲一旦表單被認爲有效,您的Javascript將重定向到Home.php。您需要在流程中的某個時刻提交表單,以便實際獲得一些POST值,您將使用它們來填充SESSION變量。 如果你想保持你的Javascript驗證,也許看看submit():http://www.w3schools.com/jsref/met_form_submit.asp 你必須在提交它之前在你的表單上設置一個正確的動作屬性。

+0

我沒有真正看到我沒有發佈任何東西給login.php,並且使用submit()for JS允許發佈帖子,調用header()也很好,謝謝。 – codeMonkey 2014-11-08 19:02:39

0

因此,繼承人,似乎修復是工作

<?php session_start();?> 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 

<html xmlns="http://www.w3.org/1999/xhtml"> 

<head > 
<title>Login</title> 

<link rel="stylesheet" href="style.css" type="text/css" media="screen" /> 
<meta http-equiv="content-type" content="text/html; charset=utf-8" /> 
<meta http-equiv="content-language" content="en-gb" /> 

<script type="text/javascript"> 
    // Perform Client side validation of Username and Password 
    function redirect() { 
     var username = document.getElementById("username"); 
     var password = (document.getElementById("password")); 

     if (!username.value == " ") { 
      if (!password.value == " ") { 
       if (username.value == "aknight") { 
        if (password.value == "00226291") { 
         document.forms[0].submit(); 
         exit(); 
        } else 
         alert("Username or Password Invalid"); 

       } 
      } else 
       alert("Password is required"); 

     } else 
      alert("Username is required"); 

    } 
</script> 
</head> 

<body> 
<div id="header"> 
<h1>Product Order System</h1> 
<br/> 
<h2>The most expensive crap youll ever find...</h2> 
</div> 

<div id="content"> 
<?php 

if ($_SERVER['REQUEST_METHOD'] == 'POST'){ 

    $_SESSION['username'] = $_POST['username']; 
    header('Location : ../Home.php'); 

}else{ 
?> 

<form action="Home.php" name="login" method="POST"> 
<fieldset> 
<legend>Login Information</legend> 
<p> 
<label for="Username">Username:</label> 
<input type="text" name="username" id="username" /> 
</p> 
<p> 
<label for="Password">Password:</label> 
<input type="password" name="password" id="password" /> 
</p> 
<p> 
<input type="button" name="login" value="Login" onclick=" redirect();"/> 
<input type="button" name="cancel" value="Cancel" /> 
</fieldset> 
</form> 
<?php } 

    include ('includes/footer.html'); 
?> 

將再次發佈,如果NEX系列的網頁有一個類似的問題

感謝