用户无法登录,有什么问题?

时间:2011-08-06 00:20:53

标签: php login

好的,我曾尝试与用户建立登录系统。但我的用户无法登录。这是一个问题。

我的登录页面:

<?
session_start();

include "database.php";
?>



<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
<link href="style.css" rel="stylesheet" type="text/css" />
<title>Wildsoul</title>
</head>

<body>
    <div id="welcome">
        <h3>Log ind.</h3>
<br><br>
        <p><form action="login-ok.php" method="post">
<input type="text" name="username"><br>
<input type="password" name="password"><br><br><br>
<input type="submit" name="login" value="Login">
</form></p>




                                <br /><br />

    </div>
                    </div>
    </body>
</html>

登录确定页面:

<?
session_start();

include "database.php";
?>



<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
<link href="style.css" rel="stylesheet" type="text/css" />
</head>

<body>
<div id="container">
        <div id="welcome">
        <h3>Log in</h3>
        <p><?php // PHP script start.
require("config.php"); // Variabler til mysql hentes
$login = &$HTTP_POST_VARS['login'];
$_SESSION['login'] = $login; //AF rettelse

if(empty($login)) {
    echo 'You need to log in'; }
    else {

$username = &$HTTP_POST_VARS['username']; // Brugernavn fra form i login.php.
$password = &$HTTP_POST_VARS['password']; // Password fra form i login.php.

if(empty($username) OR empty($password)) { //Her tjekkes om ET af felterne er tomme.
    echo 'Et af felterne er tomme'; }   
    else { // Denne klamme starter alt script der udføres HVIS begge felter er udfyldte.

// Her åbnes for mysql-serveren og der logges ind med data fra config.php.
mysql_connect($mysql_host, $mysql_user, $mysql_pw);
mysql_select_db($mysql_db); // Der åbnes for databasen defineret i config.php.


 $result_pw = mysql_query("select password from users where brugernavn = '$username'") or die (mysql_error()); 
$result_user = mysql_query("select brugernavn from users where password = '$password'") or die (mysql_error()); 


// Her sker det egentlige tjek om brugernavn og password er dem som står i databasen.
// Der oprettes først et array med de data vi fik fra mysql før.
$array_user = mysql_fetch_array($result_user); // Først et med brugernavn.
$array_pw = mysql_fetch_array($result_pw); // Og et med password.
// Her tjeckes så om både array med brugernavn og password indeholder data
// magen til dem skrevet i felterne i html-formen
// PASSWORD KONTROL
if($array_user['username'] == $username AND $array_pw['password'] == $password) {
  echo 'correct password. <a href="http://wildsoul.dk/indeks.php">Klik her</a>.'; // Brugernavn og password passede!!
$_SESSION['username'] = $username; //AF rettelse
$_SESSION['password'] = $password; //AF rettelse 

} // Her lukker vi condition TRUE fra password kontrol

else { // Her starter condition FALSE på password kontrol
echo 'forkert password';
} // Her lukkes condition FALSE på password kontrol.

} // Her lukker vi for condition FALSE på tomme-felter-tjek.
}
?>
</p>


                                <br /><br />

    </div>
                    </div>
    </body>
</html>

当我必须检查用户是否已登录时,我有以下代码:

<?
session_start();

include "database.php";
?>

<? if(isset($_SESSION['username']) && isset($_SESSION['password'])){ ?>

bla bla bla

<?}
else{
echo 'You have to log in'; }
?>

我在哪里错了?

2 个答案:

答案 0 :(得分:0)

看起来你有一个逻辑问题,你在实际尝试验证用户之前检查$ login。删除它,然后尝试验证它们,然后设置会话变量。

所以删除if(空($ login))...然后连接到你的数据库等。如果这不起作用,尝试编辑你的帖子,除了“它不起作用” “:)

答案 1 :(得分:0)

  • 您在第一个<?之前有空格,因此无法成功启动会话 - 这可能是您的整个问题
  • 不要使用短启动PHP代码<?,而是使用<?php