1

我想压缩包含超过 1000 个变量的巨大 HTML 表单中的所有数据,以规避 5.3.9 之前 PHP 版本中的 max_input_vars 限制。

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

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

4

4 回答 4

1

刚刚发了一个ajax帖子?

带有 javascript 的 form.html

<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>

进程.php

<?php
    $name = $_POST['name'];
    // other form fields here
}
于 2013-09-30T18:06:50.980 回答
0

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

于 2013-10-01T05:57:26.737 回答
0

我创建了一个脚本,可以自动在所有帖子表单上完成这项工作:

<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>

在接收端,你不能使用 PHPparse_str()函数,因为 max_input_vars 指令也会影响这个函数,所以你需要别的东西:我my_parse_str()取自https://gist.github.com/rubo77/6821632

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

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

https://gist.github.com/rubo77/6815945上的示例脚本

于 2013-10-01T03:52:06.940 回答
0

使用 JQuery 对其进行序列化。然后,您可以使用 PHP解析 URL 字符串。

于 2013-09-30T18:05:28.407 回答