我的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();
}
}
答案 0 :(得分:12)
<?php
之前隐藏一些ascii或空白字符,只需打开记事本,从session_start()复制内容;到最后并粘贴它,现在手动添加<?php
,并确保在第1行<?php
之前没有任何空格字符
答案 1 :(得分:5)
在页面顶部使用ob_start();
,用于输出缓冲区,可以解决此问题。