我知道这已经多次发布过,但我仍然遇到问题。
当我登录我的网站时,我希望会话开始。当我开始会话时,我收到此错误。
警告:session_start()[function.session-start]:无法发送会话 cookie - 已经发送的标题(输出开始于 /home1/gretar/public_html/login.php:27)in 第30行/home1/gretar/public_html/login.php
警告:session_start()[function.session-start]:无法发送会话 缓存限制器 - 已发送的标头(输出始于 /home1/gretar/public_html/login.php:27)in 第30行/home1/gretar/public_html/login.php
所以这就是我的代码的样子
<?php
include('mysql_connect.php');
if($_SERVER['REQUEST_METHOD'] == 'POST') {
$username = mysql_real_escape_string($_POST['username']);
$password = mysql_real_escape_string(md5($_POST['password']));
$verified = mysql_real_escape_string($_POST['verified']);
$query = "SELECT * FROM members WHERE username='$username' AND password='$password'";
mysql_query("SELECT verified FROM members WHERE username='$username'");
$sql = mysql_query("SELECT verified FROM members WHERE username='$username'");
while($row = mysql_fetch_array($sql)){
$verified = $row["verified"];
};
$result = mysql_query($query);
$query_rows = mysql_num_rows($result);
if($query_rows > 0) {
if($verified == 1) {
echo("User Verified");
} else if($verified == 0) {
echo("User not verified");
}
echo ("Succesfull login!");
session_start();
$_SESSION['login'] = "1";
}else{
echo("Bad login!");
}
}
?>
<html>
<head>
<title>Login</title>
</head>
<body>
<form action="login.php" method="post"/>
Username: <input type="text" name="username"/><br>
Password <input type="password" name="password"/> <br>
<input type ="submit" value="Login!"/>
</body>
</html>
This answer真的帮了我。
答案 0 :(得分:1)
问题出在这一部分:
echo("User Verified");
} else if($verified == 0) {
echo("User not verified");
如果你想改变HTTP-Header(当你开始会话时你做了什么),你不能回复任何事情。
为什么不在文件的最开头调用session_start()?
请注意,您执行两次相同的mysql_query。
答案 1 :(得分:0)
除了在回显的第一件事之前设置cookie和其他标题之外,您还可以使用输出缓冲区。输出缓冲区允许您在打印前缓冲输出,允许php正确指定顺序。在HTTP协议中,首先是标题,然后是两个回车,然后是你的内容。