警告:session_start()[function.session-start]:无法发送会话缓存限制器 - 已发送的标头

时间:2013-09-07 05:36:06

标签: php

我的php代码收到错误:

Warning: session_start() [function.session-start]: Cannot send session cache limiter - headers already sent (output started at /home4/iamden83/public_html/loop/signup.php:1) in /home4/iamden83/public_html/loop/signup.php on line 2

代码就是这个

<?php
session_start();
// If user is logged in, header them away
if( isset( $_SESSION["username"] ) ){
    header( "location: message.php?msg=NO to that weenis" );
    exit();
}
?><?php
// Ajax calls this NAME CHECK code to execute
if(isset($_POST["usernamecheck"])){
    include_once("php_includes/db_conx.php");
    $username = preg_replace('#[^a-z0-9]#i', '', $_POST['usernamecheck']);
    $sql = "SELECT id FROM users WHERE username='$username' LIMIT 1";
    $query = mysqli_query($db_conx, $sql); 
    $uname_check = mysqli_num_rows($query);
    if (strlen($username) < 3 || strlen($username) > 16) {
        echo '<strong style="color:#F00;">3 - 16 characters please</strong>';
        exit();
    }
    if (is_numeric($username[0])) {
        echo '<strong style="color:#F00;">Usernames must begin with a letter</strong>';
        exit();
    }
    if ($uname_check < 1) {
        echo '<strong style="color:#009900;">' . $username . ' is OK</strong>';
        exit();
    } else {
        echo '<strong style="color:#F00;">' . $username . ' is taken</strong>';
        exit();
    }
}

2 个答案:

答案 0 :(得分:12)

嗯,我认为必须在<?php之前隐藏一些ascii或空白字符,只需打开记事本,从session_start()复制内容;到最后并粘贴它,现在手动添加<?php,并确保在第1行<?php之前没有任何空格字符

答案 1 :(得分:5)

在页面顶部使用ob_start();,用于输出缓冲区,可以解决此问题。