好的,这让我很生气。我有2个模态表单 - 登录和注册。 Javascript进行客户端验证,然后ajax调用运行注册php文件或登录php文件,如果成功则返回OK,或者指示错误的特定错误消息(密码不正确,用户名已经用完等)。有一个If Then语句检查返回消息是否正常,如果是,则显示成功消息,其他字段隐藏。
注册表格完美无缺。我恢复正常,字段隐藏,显示成功消息。
登录表单不起作用。一个成功的登录返回OK,但if语句失败,而不是一个格式良好的成功消息,我只是显示OK而没有隐藏用户名和密码字段,这让我觉得IF失败了虽然我不明白为什么它会
我一直在盯着这段代码好几个小时,我能看到的两个代码都是相同的,不知道为什么一个人在工作,一个人不在......
关于代码......这是Login javascript:
$("#ajax-login-form").submit(function(){
var str = $(this).serialize();
$.ajax({
type: "POST",
url: "php/login.php",
data: str,
success: function(msg) {
$("#logNote").ajaxComplete(function(event, request, settings) {
if(msg == 'OK') {
// Display the Success Message
result = '<div class="alertMsg success">You have succesfully logged in.</div>';
$("#ajax-login-form").hide();
$("#swaptoreg").hide();
$("#resetpassword").hide();
} else {
result = msg;
}
// On success, hide the form
$(this).hide();
$(this).html(result).slideDown("fast");
$(this).html(result);
});
}
});
return false;
});
这里是注册javascript:
$("#ajax-register-form").submit(function(){
var str = $(this).serialize();
$.ajax({
type: "POST",
url: "php/register.php",
data: str,
success: function(msg) {
$("#regNote").ajaxComplete(function(event, request, settings) {
if(msg == 'OK') {
// Display the Success Message
result = '<div class="alertMsg success">Thank you! Your account has been created.</div>';
$("#ajax-register-form").hide();
} else {
result = msg;
}
// On success, hide the form
$(this).hide();
$(this).html(result).slideDown("fast");
$(this).html(result);
});
}
});
return false;
});
我认为我不需要在这里添加php,因为两者都只是以'OK'结尾;如果成功,因为我看到OK而不是格式良好的成功消息,我相信它正在发挥作用。
有什么建议吗?
编辑:这是登录php:
<?php
require("common.php");
$submitted_username = '';
$user = stripslashes($_POST['logUser']);
$pass = stripslashes($_POST['logPass']);
if(!empty($_POST))
{
$query = "
SELECT
id,
username,
password,
salt,
email
FROM users
WHERE
username = :username
";
$query_params = array(
':username' => $user
);
try
{
$stmt = $db->prepare($query);
$result = $stmt->execute($query_params);
}
catch(PDOException $ex)
{
die("Failed to run query ");
}
$login_ok = false;
$row = $stmt->fetch();
if($row)
{
$check_password = hash('sha256', $pass . $row['salt']);
for($round = 0; $round < 65536; $round++)
{
$check_password = hash('sha256', $check_password . $row['salt']);
}
if($check_password === $row['password'])
{
$login_ok = true;
}
}
if($login_ok)
{
unset($row['salt']);
unset($row['password']);
$_SESSION['user'] = $row;
echo 'OK';
}
else
{
echo '<div class="alertMsg error">Incorrect username or password</div>';
$submitted_username = htmlentities($_POST['username'], ENT_QUOTES, 'UTF-8');
}
}
?>
答案 0 :(得分:2)
if($login_ok)
{
unset($row['salt']);
unset($row['password']);
$_SESSION['user'] = $row;
echo 'OK';
}
else
{
echo '<div class="alertMsg error">Incorrect username or password</div>';
$submitted_username = htmlentities($_POST['username'], ENT_QUOTES, 'UTF-8');
}
}
?> <!------- There is a space here! -->
在发送给用户的结束?>
之后有一个空格。结束?>
是可选的,强烈建议不要包括它,因为这个原因。摆脱?>
。