0

わかりましたので、これは私を怒らせています。ログインと登録の 2 つのモーダル フォームがあります。Javascript がクライアント側の検証を行い、次に ajax 呼び出しが登録 php ファイルまたはログイン php ファイルのいずれかを実行し、成功した場合は OK を返すか、何が間違っているかを示す特定のエラー メッセージ (パスワードが正しくない、ユーザー名が既に使用されているなど) を返します。戻りメッセージが OK かどうかをチェックする If Then ステートメントがあり、OK である場合は成功メッセージが表示され、他のフィールドは非表示になります。

登録フォームは完璧に機能します。OK が返され、フィールドが非表示になり、成功メッセージが表示されます。

ただし、ログインフォームは機能しません。ログインに成功すると OK が返されますが、if ステートメントが失敗し、うまくフォーマットされた成功メッセージの代わりに、ユーザー名とパスワードのフィールドが非表示になることなく OK が表示されるだけです。 .

私は今、このコードを何時間も見つめてきましたが、私が見ることができるのは両方の同じコードであり、なぜ一方が機能し、もう一方が機能していないのかわかりません....

コードに...これがログイン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;
        });

どちらもエコー「OK」で終わるだけなので、ここにphpを追加する必要はないと思います。成功した場合、適切にフォーマットされた成功メッセージの代わりに 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'); 
    } 
} 

?> 
4

1 に答える 1