登录 - 不想重定向


Login - Does not want to redirect

已解决:有一个愚蠢的错误导致了这个问题。在标头中.php我写了 $_SESSION["header"](甚至不存在)而不是 $_SESSION["logged"]。感谢大家的帮助。

登录.php不想在我输入正确的登录信息后重定向。

页面仅刷新并清除输入字段。

(会话也是在/tmp 文件夹中创建的)

有人有什么想法吗? :S

提前感谢! :)

登录.php:

<?php
$message = NULL;
if (isset($_POST["enter"])) {
    include 'cred.php';
    $newUser = $_POST["user"];
    $newPass = md5($_POST["pass"]);
  if ($newUser==$user AND $newPass==$pass) {
    session_start();
    $_SESSION["logged"]=1;
    $_SESSION["user"]=$newUser;
    header('Location: index.php');
    exit;
  } else {
    $message = 'failure';
  }
}

?>
<head>
<style type="text/css">
body {
    margin-top:120px;
}
</style>
</head>
<body>
<center>
<form method="post" action="<?php echo $_SERVER['PHP_SELF']; ?>" enctype="multipart/form-data">
Uporabnik:<br /> <input type="text" name="user" /><br /><br />
Geslo:<br /> <input type="password" name="pass" /><br /><br />
<input type="submit" value="submit" name="enter"/><br /><br />
<?php if($message!=NULL) {echo $message;} ?>
</form>
</center>
</body>

信誉.php:

<?php
$user = 'janeznovak';
$pass= md5('greek123');
?>

编辑:添加了标题.php文件,该文件是每个(索引.php,第二.php,第三.php)页面的一部分。也许问题就在这里:

<?php
session_start();
if(!isset($_SESSION["header"])OR $_SESSION["header"]!=1){
    header('Location: login.php');
    exit;

} else {
    $nuser = $_SESSION["user"];
}

?>
<head>
</head>
<body>
<div>
<a href="index.php">Prva</a> | 
<a href="second.php">Druga</a> | 
<a href="third.php">Tretja</a> | 
<a href="logout.php">Logout</a> | 
Prijavljeni ste kot <?php echo $nuser; ?>
</div> 
登录

时再添加一个会话变量.php

 session_start();
$_SESSION["logged"]=1;
$_SESSION["header"] = 1;
$_SESSION["user"]=$newUser;
header('Location: index.php');

希望现在它会起作用。

您是否已经尝试仅使用带有 action=" 而不是 action=" 的表单

还要给输入类型一个 ID 并添加 session_start(); 打开 php 后:

编辑:我也不明白为什么你在表单页面中使用,同时包含标题.php标题已经包含其中。

我也没有看到您在任何地方设置会话 $_SESSION['header'] ?

还要更改此设置:

if(!isset($_SESSION["header"])OR $_SESSION["header"]!=1){

自:

if (!isset ($_SESSION['header'])) {
    header("Location: login.php");
} elseif ($_SESSION['header'] != 1) {
    header("Location: login.php");
}

我没有看到你在哪里包含信誉.php?添加登录名.php在第一行代码处:

include("cred.php");

我不认为检查您的用户名和密码的 if 语句实际上计算为 true。与其在那里进行重定向,不如使用 print 或 echo 语句对其进行调试。

if ($newUser==$user AND $newPass==$pass) {
    session_start();
    $_SESSION["logged"]=1;
    $_SESSION["user"]=$newUser;
    $message = "success";
  }

如果 print 语句运行,则按照其他人已经说过的做,.php并在页面顶部而不是在 if 语句内。