多个PHP"标题(url)"在脚本中,"无法修改标题信息"错误

时间:2014-04-03 13:52:43

标签: php mysql

嘿,我有一些脚本应该在符合某些标准的情况下更改页面的网址,或者如果它没有,则会在其他地方更改。

我收到此错误:

  

警告:无法修改标头信息 - 已发送的标头   (输出始于   /hermes/bosweb25c/b1401/ipg.website/process.php:7)in   第53行/hermes/bosweb25c/b1401/ipg.website/process.php

这是我的PHP。我非常确定它与if语句有关,但在我上传到我的网络主机之前,它在我的WAMP服务器上工作正常。

<?php
session_start();
$con = mysql_connect('website', 'members_db_admin', 'password'); 
if (!$con) { 
    die('Could not connect: ' . mysql_error()); 
} 
echo 'Connected successfully<br />'; 

// make members the current db
$db_selected = mysql_select_db('members_db', $con);
if (!$db_selected) {
    die ('Can\'t use members database : ' . mysql_error());
}
$hash_password = md5($_POST['password']);

$email = $_POST['email'];

$result = mysql_query("SELECT email,password FROM `members` WHERE email = '$email'");
if (!$result) {
    echo 'Could not run query: ' . mysql_error();

}

$row = mysql_fetch_row($result);

if ($row[0] != $email && $hash_password != $row[1])
{
    $query = "INSERT INTO members (email, password)
    VALUES('".$_POST['email']."','".$hash_password."')";

    // Perform Query
    $result2 = mysql_query($query);

    // Check result
    // This shows the actual query sent to MySQL, and the error. Useful for debugging.
    if (!$result2) {
        $message  = 'Invalid query: ' . mysql_error() . "\n";
        //$message .= 'Whole query: ' . $query;
        die($message);
    }   
$_SESSION['email']=$_POST['email'];
$_SESSION['password']=$hash_password;
$_SESSION['loggedin']="YES";
$url = "Location: /welcome.php";
header($url);
}
$_SESSION['email']=$_POST['email'];
$_SESSION['password']=$hash_password;
$url = "Location: /checklogin.php";
header($url);
?>

3 个答案:

答案 0 :(得分:2)

您的问题是echo 'Connected successfully<br />';。在使用header()调用设置标头之前,您无法打印任何内容。确保您的echo之前没有header()次来电。

答案 1 :(得分:0)

尝试ob_start();在session_start();

之后

答案 2 :(得分:0)

如果您使用utf-8作为此文件的编码,请尝试将其保存而不会导致此类问题。