Возвращаемое значение из формы ajax
У меня есть форма входа в php. Я использовал ajaxform, чтобы страница не перезагружалась при неправильном имени пользователя или пароле. У меня есть другая страница checklogin.php, которая проверяет, есть ли имя пользователя и pw в базе данных, и возвращает количество строк. Я хочу сравнить количество в login.php и отобразить сообщение об ошибке, если count=1, и перенаправить на другую страницу, если count=2. Я пытался отобразить счетчик в errordiv, используя target: 'errordiv' и проверяя его innerHTML, но это не удалось сделать.
Мой логин.php
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.8/jquery.min.js"></script>
<script type="text/javascript" src="scripts/jquery.form.js"></script>
<!--Slider-in icons-->
<script type="text/javascript">
function checklogin()
{
var request=$("#login-form").ajaxForm(
{
target:'#errordiv'
}).abort();
request.submit();
var divmsg=document.getElementById("errordiv");
if (divmsg.childNodes[0].nodeValue == "1")
{
divmsg.childNodesp[0].nodeValue="Sorry";
alert ("Invalid username or password");} //I didn't get the alert as well a the divmsg content didn't change
};
</script>
</head>
<body>
<!--WRAPPER-->
<div id="wrapper">
<!--LOGIN FORM-->
<form name="login-form" id="login-form" class="login-form" action="checklogin.php" method="post">
<!--CONTENT-->
<div class="content">
<!--USERNAME--><input name="un" type="text" class="input username" placeholder="Username" onfocus="this.value=''" required="required" /><!--END USERNAME-->
<!--PASSWORD--><input name="pw" type="password" class="input password" placeholder="Password" onfocus="this.value=''" required="required" /><!--END PASSWORD-->
</div>
<!--END CONTENT-->
<!--FOOTER-->
<div class="footer">
<!--LOGIN BUTTON--><input type="submit" name="submit" value="Login" class="button" onclick="checklogin()" /><!--END LOGIN BUTTON-->
</div>
<!--END FOOTER-->
</form>
<div id="errordiv" class="errordiv"></div>
<!--END LOGIN FORM-->
checklogin.php
<?php
include ('dbconn.php');
$user = trim($_POST['un']);
$pass = trim($_POST['pw']);
$user = mysql_real_escape_string($user);
$pass = mysql_real_escape_string($pass);
$result=mysql_query("select Id from login where Username='$user' and Password='$pass'") or die (mysql_error());
$result= mysql_fetch_assoc($result);
$num= count ($result);
echo $num;
?>
Как я могу получить значение $num в login.php, не отображая его в div, сравнить значение $num и, соответственно, отобразить errormsg в errordiv или, если $num==2 перенаправить на другую страницу.
2 ответа
Измените свой код, включив в него код, который изменяет div и выдает предупреждение для включения в обратный вызов.
var request=$("#login-form").ajaxForm(
{
target:'#errordiv',
success: function (html) {
if ($("#errordiv).html() == "1") {
$("#errordiv).html("Sorry");
alert ("Invalid username or password");
}
}
}).abort();
request.submit();
Может быть, попытаться сделать запрос проверки асинхронно и обработать обратную связь с пользователем в обратном вызове AJAX:
JS:
$(function(){
$("#login-form").ajaxForm(function(response){
if(response.count===1){
$("#errordiv").html("msg you want to show");
}else if(response.count===2){
//redirect
}
});
});
PHP:
<?php
header("Content-Type: application/json");
//your database check logic
$user = trim($_POST['un']);
$pass = trim($_POST['pw']);
$user = mysql_real_escape_string($user);
$pass = mysql_real_escape_string($pass);
$result=mysql_query("select Id from login where Username='$user' and Password='$pass'") or die (mysql_error());
$result= mysql_fetch_assoc($result);
$num= count ($result);
//and return response in JSON
echo json_encode(array("count"=>$num));
?>
Надеюсь, это полезно для вас.
[РЕДАКТИРОВАТЬ]
удалить кнопку отправки формы встроенной функции JS, вызывающей:
onclick="checklogin()"
и поместите логику функции checklogin, чтобы документировать готовый обратный вызов, инициализировать форму, когда DOM будет готов