2

jQuery:

$("#btnSaveForm").click(function(){
...
$.post('../optional/setup/processItemcn.php', $("#FormTemplate").serialize(), function(data) {
     alert(data);
});
...
});

带有表单的php:

<form id="FormTemplate" class="FormTemplate">
  <input type="text" name="kode_item[]" value="1" />
  <input type="text" name="kode_item[]" value="2" />
  <input type="text" name="kode_item[]" value="3" />
  .
  .
  <input type="text" name="kode_item[]" value="197" />
</form>

服务器端的php:

$ID = $_POST["kode_item"];
$count = count($ID);   
echo "$count";

我正在尝试使用 jquery post 和序列化将所有数组数据从表单发送到服务器端。我有 kode_item = 197 个项目的总项目数组,但是在将其发送到服务器端然后我从服务器端检查并回显它 $count = 167 个项目的结果。这就是为什么我无法更新与 kode_item > 167 相关的数据,因为它不会在服务器端处理。有人有想法么 ?

4

3 回答 3

1

尝试检查您的 php.ini 中的设置是否正确

; Maximum size of POST data that PHP will accept.
post_max_size = 8M
于 2013-02-13T12:01:52.620 回答
1

我也遇到了这个问题,但没有找到解决方案,在阅读了 jQuery 文档后,我有了一个想法。

您可以使用.serializeArray()而不是仅.serialize()使用 php.ini 文件。这是我在项目中使用的代码。

jQuery('.modal').on('click','.saveFeature',function(){ 

        var form = jQuery('#featureForm').serializeArray();
        jQuery.ajaxSetup({
            data:{
                csrf_name:jQuery('input[name="csrf_name"]').val()
            }
        });
        var url = "<?php echo 'product/features/'.$pid;?>";
        jQuery.post(url,{form}, function(msg){
            alert(msg);
        } );
    });

提交表单后,您将获得以下格式的数据。

Array
(
[0] => Array
    (
        [name] => csrf_name
        [value] => 3802b11296d42e602533bf266bb800bd
    )

[1] => Array
    (
        [name] => title
        [value] => kjhkjh
    )

[2] => Array
    (
        [name] => title_icon
        [value] => fa fa-heart
    )

[3] => Array
    (
        [name] => icon_color
        [value] => #a81616
    )

[4] => Array
    (
        [name] => icon_bg_color
        [value] => #662f2f
    )

[5] => Array
    (
        [name] => description
        [value] => testb
    )

[6] => Array
    (
        [name] => box_bg_color
        [value] => #bd2222
    )

[7] => Array
    (
        [name] => box_bttm_bg
        [value] => #a61e1e
    )

)

在后端处理发布数据时,我使用的是 CodeIgniter 框架。以格式组织该帖子数据,key=>value以便于存储数据。

$arry = $this->input->post('form');
    $post = [];
    //check if this is not empty and is array
    if(!empty($arry) && is_array($arry)){
        //iterate over post data and organize array in key value format.
        foreach($arry as $ar) 
        {
            $post[$ar['name']] = $ar['value'];
        }
    }

    $data = [
        'pid' => $pid,
        'title' => $post['title'],
        'icon' => $post['title_icon'],
        'icon_color' => $post['icon_color'],
        'icon_bg_color' => $post['icon_bg_color'],
        'description' => $post['description'],
        'box_bg_color' => $post['box_bg_color'],
        'box_bttm_color' => $post['box_bttm_bg'],
    ];

    $this->db->insert(TBL_PRODUCT_FEATURES, $data);

如我错了请纠正我; 我刚刚分享了解决这个问题的想法。

于 2017-08-11T05:25:13.093 回答
0

解决方案来自我的虚拟主机技术人员。

从表单发送到服务器端的数组数据太长了,然后.. suhosin限制了将要发送的数组数据。

这种方式对我有用。将这两行添加到 php.ini:

suhosin.post.max_vars = 1500
suhosin.request.max_vars = 1500
于 2013-02-14T08:54:42.463 回答