您好,匿名用户
随意问技术百科期待您的加入

php提示「headers already sent by」是怎么回事?

0 投票

错误提示:
SAE_Warning: Cannot modify header information - headers already sent by (output started at /data1/www/htdocs/345/leank/1/bbs/login.php:15) in bbs/login.php on line 9

SAE_Warning: Cannot modify header information - headers already sent by (output started at /data1/www/htdocs/345/leank/1/bbs/login.php:15) in bbs/login.php on line 10

SAE_Warning: Cannot modify header information - headers already sent by (output started at /data1/www/htdocs/345/leank/1/bbs/login.php:15) in bbs/login.php on line 28

SAE_Warning: Cannot modify header information - headers already sent by (output started at /data1/www/htdocs/345/leank/1/bbs/login.php:15) in bbs/login.php on line 29

大致的代码:

<?php
/*
* 未完成内容 : 添加判断的url中log?= "" 的if语句,来判断用户是登陆还是退出
*添加一个判断是否已经登陆的if语句
*
*/
include("conn.php");
function clearcookies(){
    setCookie('username','',time()-3600);
    setCookie('logset','',time()-3600);
}
?>
  <?php
    if ($_POST['loginsubmit'])  //检查是否提交
    {
        clearcookies();
        $sql = "SELECT * FROM user WHERE username = '$_POST[username]'";
        $query = mysql_query($sql);
        $userinfo = mysql_fetch_array($query);
        if ($_POST[password] != "" & $_POST[username] != "") //检查用户名密码是否填写
        {
            if ($userinfo['password'] == $_POST['password'] ) //在SQL中检查用户名密码是否正确
            {
                $username = $_POST[username];
                
                setcookie('username','$username',time()+31536000,'/');
                setcookie('logset','ok',time()+31536000,'/');
                echo "<meta http-equiv=refresh content=0;url=index.php?foo=$_POST[username]>";
            }
            else
            {
                echo "登录失败!";
                echo "请检查您的用户名或密码是否都填写正确";
            }
        }
        else
        {
            echo "登录失败!";
            echo "请检查您的用户名或密码是否为空";
        }
    }
  ?>

处错误的大致是这个位置:
setcookie('username','$username',time()+31536000,'/');
setcookie('logset','ok',time()+31536000,'/');

用户头像 提问 2012年 12月1日 @ Twisted Fate 上等兵 (184 威望)
分享到:

1个回答

0 投票
 
最佳答案

因为在setCookie之前多输出了东西造成的,看代码似乎是输出了空格,把中间的

?>
  <?php

去掉应该就可以了

用户头像 回复 2012年 12月1日 @ Miss Fortune 上等兵 (418 威望)
选中 2012年 12月1日 @Twisted Fate
提一个问题:

相关问题

+1 投票
1 回复 35 阅读
用户头像 提问 2012年 12月1日 @ Ezreal 上等兵 (266 威望)
0 投票
1 回复 37 阅读
0 投票
1 回复 5 阅读
用户头像 提问 2014年 5月26日 @ Fiora 上等兵 (297 威望)
0 投票
1 回复 41 阅读
用户头像 提问 2012年 12月1日 @ Jax 上等兵 (324 威望)

欢迎来到随意问技术百科, 这是一个面向专业开发者的IT问答网站,提供途径助开发者查找IT技术方案,解决程序bug和网站运维难题等。
温馨提示:本网站禁止用户发布与IT技术无关的、粗浅的、毫无意义的或者违法国家法规的等不合理内容,谢谢支持。

欢迎访问随意问技术百科,为了给您提供更好的服务,请及时反馈您的意见。
...