使用javascript压缩所有表单数据

时间:2013-09-30 17:48:26

标签: php

我想压缩来自包含1000多个变量的大型HTML表单中的所有数据,以绕过5.3.9之前的PHP版本中的max_input_vars限制。

如何使用javascript读取HTML表单中的所有数据,将其序列化(或创建json)以将其全部放在包含整个数据的一个隐藏字段中?

在接收方,我会用PHP解压缩它(例如用json_decode

4 个答案:

答案 0 :(得分:1)

刚发了一个ajax帖子?

form.html with javascript

<form action="process.php" method="post" id="form">
  <input type="text" name="name">
  <input type="text" name="username">

  <button type="submit" id="sendForm">Send</button>
</form>

<!-- YOUR JAVASCRIPT -->
<script type="text/javacript">
  $('#sendForm').click(function() {

    $.ajax({
      type: 'POST',
      url: $('#form').attr('action'),
      data: $('#form').serialize(),
      success: function(data) {

        // WHATEVER YOU WANT HERE

      }
    });

    return false;
  });
</script>

process.php

<?php
    $name = $_POST['name'];
    // other form fields here
}

答案 1 :(得分:1)

我创建了一个脚本,可以自动完成所有帖子表格的工作:

<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script>
<script>
// this disables all form elements and creates only one new element that contains all data serialized
$('form[method="post"]').submit(function() {
    var num_form_elements=$(this).find('input, select, textarea').not('[type="submit"]').length;
    var num_elements_already_disabled=$(this).find('input:disabled, select:disabled, textarea:disabled').length;
    enabled=(num_form_elements-num_elements_already_disabled);
    if($('textarea[name="serialized_data"]', this).length > 0) {
        alert("Backbutton is not supported yet!");
        return false;
    }
    if($('textarea[name="serialized_data"]', this).length > 0 || enabled<=0) {
        alert("Reload of the form is not supported yet!");
        return false;
    }
    var data=$(this).serialize();
    $(this).find('input, select, textarea').not('[type="submit"]').attr("disabled", true);
    $(this).append('    <input type="hidden" name="num_form_elements" value="'+num_form_elements+'">'); 
    $(this).append('    <input type="hidden" name="num_elements_already_disabled" value="'+num_elements_already_disabled+'">'); 
    $(this).append('    <textarea style="display:true" name="serialized_data">'+(data)+'</textarea>');
    // maybe in the textarea I have to .replace(/</g,'&lt;') ?

});
</script>

在接收方,您无法使用PHP parse_str()函数,因为max_input_vars指令也会影响此函数,因此您需要其他内容:我从https://gist.github.com/rubo77/6821632

获取了my_parse_str()
<?php
    $params=my_parse_str($_REQUEST['serialized_data']);

    echo count($params,1)." serialized variables:<br>";
    var_export($params);
?>

https://gist.github.com/rubo77/6815945

上的示例脚本

答案 2 :(得分:0)

Serialize it using JQuery。然后,您可以parse the URL string使用PHP。

答案 3 :(得分:0)

也许序列化和JSON.stringify可以一起工作,虽然我没有尝试过。