0

我在另一个站点上有一个工作登录脚本,它通过 AJAX 加载 PHP 脚本。我似乎无法弄清楚为什么当它应该是简单的错误或值数组时我得到一个空响应。

当我手动将值放入 php 脚本(硬编码)时,它可以工作。我可以在控制台中看到变量是从表单发送的。但是,没有任何东西被退回。谁能发现我错过了什么?

感谢您的任何帮助或想法。

登录 PHP

<?php 
$login = $_POST['login'];
$password = $_POST['password'];

require_once("DB.php");
$connection = mysql_connect($host, $user, $pass) or die ("Unable to connect!"); 
mysql_select_db($db) or die ("Unable to select database!"); 

$query = "SELECT * FROM members WHERE login='$login' AND passwd='".md5($_POST['password'])."'";
$result = mysql_query($query) or die ("Error in query: $query. ".mysql_error()); 
if (mysql_num_rows($result) > 0) { 
$output = "true";
     while(list($member_id, $firstname, $lastname, $login, $passwd, $City, $State, $bday, $approved, $organization, $school, $trainingdate, $Subscriber, $wscoordinator, $Position, $subdate, $enddate, $notice, $book, $trial)  = mysql_fetch_row($result)) { 
echo json_encode(array('memberid' => $member_id, 'firstname' => $firstname, lastname => $lastname, approved => $approved, subscriber => $Subscriber, position => $Position, school => $school, login => $login, book =>$book, ws => $wscoordinator, trial => $trial, enddate => $enddate));
}
} else {
$output = "false";
echo json_encode($output);
}


?>

AJAX,使用 jQuery。

$('#loginForm #loginButton').click(function(){
        var $form = $('#loginForm'),
    $inputs = $form.find("input"),
    serializedData = $form.serialize();
    var login = $('#login').text('');
    var password = $('#password').text('');
    $.ajax({
      type: 'POST',
      url: 'Scripts/php/login.php',
      data: serializedData,
      success: function(response){
        console.log("Response: "+response);
        if(response != "false") 
        {
        //window.location.href='toolstart.html';
        $.cookie('lastname', response.lastname, { expires: 365, path: '/' });
        } else {
        alert("Your email and password combination did not match.");
        }

        },      
  dataType: 'json'
});    

(是的,我知道我需要从 MD5 迁移;只是还没有到达那里。)

4

2 回答 2

0

几天后,我做了更多的研究。事实证明,我的客户端使用的服务器最高只支持 PHP 5.1,而 json_encode 仅在 5.1 中支持。找到了这个很棒的脚本来让它工作。http://www.botell.com/scripts/jsonwrapper.html

感谢所有的帮助。

于 2012-07-08T22:31:43.323 回答
0

只需替换.text();.val()as即可text()为文本输入类型提供空白结果。val()将给出实际值。其次使用var_dump($_POST); die;. 啊...检查您的功能是否:

$('#loginForm #loginButton').click(function(){
        var $form = $('#loginForm'),
    $inputs = $form.find("input"),
    serializedData = $form.serialize();
    var login = $('#login').text('');
    var password = $('#password').text('');
    $.ajax({
      type: 'POST',
      url: 'Scripts/php/login.php',
      data: serializedData,
      success: function(response){
        console.log("Response: "+response);
        if(response != "false") 
        {
        //window.location.href='toolstart.html';
        $.cookie('lastname', response.lastname, { expires: 365, path: '/' });
        } else {
        alert("Your email and password combination did not match.");
        }

        },      
  dataType: 'json'
});**});**

正如我发现的那样,缺少一些花括号。请回复您的var_dump($_POST);die;信息。

于 2012-07-06T13:34:44.790 回答