2016-11-23 108 views
2

我一直在這裏搜索所有相關的問題,仍然無法找出我有問題。Ajax提交表單在PHP中的序列化數據爲空

我用一個簡單的模式窗體:

 <p id="messages">Let's make today a great day!</p> 
<form id="myloginform" name="myloginform" action="scripts/login.php" method="post" > 
    <div class="form-group"> 
    <label for="username" class="">Enter username</label> 
    <input type="text" class="form-control input-lg c-square" id="username" name="username" placeholder="Username" required> </div> 
    <div class="form-group"> 
    <label for="password" class="">Enter pass</label> 
    <input type="password" class="form-control input-lg c-square" id="password" name="password" placeholder="Password" required> </div> 
    <div class="form-group"> 
    <div class="c-checkbox"> 
    <input type="checkbox" id="login-rememberme" class="c-check"> 
    <label for="login-rememberme" class="c-font-thin c-font-17"> 
    <span></span> 
    </div> 
    </div> 
    <div class="form-group"> 
    <button type="submit" class="btn c-theme-btn btn-md c-btn-uppercase c-btn-bold c-btn-square c-btn-login" id="check">login</button> 

    </div> 

    </form> 

我使用Ajax的形式傳遞到PHP文件:

 <script> 
    $(document).ready(function(){ 

      $('form#myloginform').submit(function(e) { 

       var my_data = $('form#myloginform').serialize(); 

       $.ajax({ 
        type  : 'POST', 
        url   : 'scripts/login.php', 
        cache  : false, 
        data  : my_data, 
        contentType : false, 
        processData : false, 
        dataType: 'json', 

        success: function(response) { 
         //TARGET THE MESSAGES DIV IN THE MODAL 
         if(response.type == 'success') { 
          $('#messages').addClass('alert alert-success').text(response.message); 
         } else { 
          $('#messages').addClass('alert alert-danger').text(response.message); 
         } 
        } 
       }); 
       e.preventDefault(); 
      }); 
     }); 
     </script> 

的login.php中的文件是非常簡單的,並返回一個json $輸出響應

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

    if($username == "Test"){ 
    $success = true; 
    } 

if($success == true) { 
    $output = json_encode(array('type'=>'success', 'message' => $username)); 
} else { 
    $output = json_encode(array('type'=>'error', 'message' => $username)); 
} 

die($output); 
?> 

所有情況下的$輸出都返回null。我檢查與螢火蟲,並且一切都很好,沒有錯誤,POST完美仍然我無法獲得變量在PHP的工作。有任何想法嗎 ???我的方法有問題,或者我需要反序列化php文件中的數據,不知何故...?

+3

刪除'contentType'和'processData'選項,您剛剛關閉了jQuery在將序列化表單發送到服務器之前將其分析爲www-urlencoded數據的所有內容。 – adeneo

+0

完美,謝謝! – Dions

回答

0

不要使用模具。 使用回聲或打印。
也設置contentType爲true。