Usamos cookies para medir audiência e melhorar sua experiência. Você pode aceitar ou recusar a qualquer momento. Veja sobre o iMasters.
Tenho um sistema de Login, que já funciona em outro site e estou tentando transferir pra outro, e não funciona de jeito nenhum. Gostaria que alguém desse uma olhada. Se digito um usuário errado, retorna um erro de usuário inválido, então está checando o banco. Quando insiro um usuário certo, aparece as seguintes mensagens de erro:
Warning: session_start(): Cannot send session cookie - headers already sent by (output started at /home/netosale/public_html/e-educacao/validacao.php:2) in /home/netosale/public_html/e-educacao/validacao.php on line 28
Warning: session_start(): Cannot send session cache limiter - headers already sent (output started at /home/netosale/public_html/e-educacao/validacao.php:2) in /home/netosale/public_html/e-educacao/validacao.php on line 28
Warning: Cannot modify header information - headers already sent by (output started at /home/netosale/public_html/e-educacao/validacao.php:2) in /home/netosale/public_html/e-educacao/validacao.php on line 36
Vou lá nessas duas linhas, e não consigo localizar absolutamente nada de anormal. O que pode estar acontecendo. Já baixei diversos outros sistemas de login, e todos dão erro. Será que é algum problema bom o bootstrap ou coisa parecida? Segue código pra que dêem uma olhada:
<?php
// Verifica se houve POST e se o usuсrio ou a senha щ(sуo) vazio(s)
if (!empty($_POST) AND (empty($_POST['usuario']) OR empty($_POST['senha']))) {
header("Location: index.php"); exit;
}
// Tenta se conectar ao servidor MySQL
mysql_connect('localhost', 'xzthyb45', '164544515151561') or trigger_error(mysql_error());
// Tenta se conectar a um banco de dados MySQL
mysql_select_db('ljklfdfjkldj') or trigger_error(mysql_error());
$usuario = mysql_real_escape_string($_POST['usuario']);
$senha = mysql_real_escape_string($_POST['senha']);
// Validaчуo do usuсrio/senha digitados
$sql = "SELECT `id`, `nome`, `nivel` FROM `userPerms` WHERE (`usuario` = '".$usuario ."') AND (`senha` = '". sha1($senha) ."') AND (`ativo` = 1) LIMIT 1";
$query = mysql_query($sql);
if (mysql_num_rows($query) != 1) {
// Mensagem de erro quando os dados sуo invсlidos e/ou o usuсrio nуo foi encontrado
echo "Login invсlido!"; exit;
} else {
// Salva os dados encontados na variсvel $resultado
$resultado = mysql_fetch_assoc($query);
}
// Se a sessуo nуo existir, inicia uma
if (!isset($_SESSION)) session_start();
//Salva os dados encontrados na sessуo
$_SESSION['UsuarioID'] = $resultado['id'];
$_SESSION['UsuarioNome'] = $resultado['nome'];
$_SESSION['UsuarioNivel'] = $resultado['nivel'];
// Redireciona o visitante
header("Location: novaTela.php");
exit;
?>Era exatamente isso Gabriel. Obrigado pela força. Tava pra ficar maluco pois não achava. O erro tava no início do arquivo, onde deixei uma linha em branco. E também na session, que não estava exatamente no começo. Provavelmente eu acertava uma coisa e deixava a outra.
Os três erros são praticamente o mesmo.
>
Citar
headers already sent
Basicamente você está tentando adicionar alguma informação ao cabeçalho (cookies, session, etc...), mas os cabeçalhos já foram enviados para o browser. Isso acontece quando algum código realiza algum output para o browser, seja proposital ou não.
Os motivos podem ser diversos, mas o mais comum de todos é um espaço em branco (ou qualquer outro texto) antes da tag de aberto do PHP (os comentários são apenas para informar aonde está o espaço):
//<- espaço em branco
>
Citar
Notice: Undefined index
Existe também uma chance remota de estar utilizando o arquivo como o Byte-Order Mark selecionado (mas isso exibiria um caracter estranho no navegador) ou utilizando alguma função de controle de output.