sql >> Base de Datos >  >> RDS >> Mysql

devolver mysql echo como error en ajax

Tenga una comprensión clara de la devolución de llamada exitosa de jquery.Ajax. La documentación dice:Una función que se llamará si la solicitud tiene éxito.

En su caso, la solicitud es exitosa si el nombre de usuario y la contraseña ingresados ​​son incorrectos.

Para que funcione correctamente, cambie su código php de esta parte a:

$redirect = '';
if($UserData['UserName'] != '')
{
    session_start();
    $error = 0;
    $message = 'Valid';
    $_SESSION['UserId'] = $myusername;

    $typ = $UserData['Type_user'];

    if($typ == "Dealer")
    {
        $redirect = 'Dealer/EditLoginDetails.php';
    }
    else if($typ == "Individual")
    {
        $redirect = '/Dealer/EditLoginDetails.php';
    }
    else
    {
        $redirect = '/Builder/managep.php';
    }
}
else
{
    $error = 1;
    $message = 'Invalid username or password';
}

echo json_encode(array('error' => $error, 'message' => $message, 'redirect' => $redirect));

Y código jquery para,

$.ajax({
    url : formURL,
    type: "POST",
    data : postData,
    dataType:'json',
    success:function(data, textStatus, jqXHR) {
        if(data.error == 1) {
            $("#simple-msg").html('<pre><code class="prettyprint">'+data.message+'</code>< /pre>');
        } else {
            window.location = data.redirect;
        }
    }
});
'); } else { ventana.ubicación =datos.redirect; } }});