2014-11-08 90 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系列的网页有一个类似的问题

感谢