通常我们使用ajax与php交互时,我习惯查询用GET方式,提交数据以POST方式。我们都知道POST默认情况下可以一次提交8M的数据,这算是一个非常大的量了,一般情况下我们一次提交的数据基本是不会超过这个数。然而,PHP从5.3.9开始增加了一个变量max_input_vars,用来提交限制表单数量。踩这个坑是在一次数据提交中,由于是列表多选,提交的时候总出错。debug的时候,打印$_POST发现每次都是刚好1000个元素,而有些固定的参数居然没有了。第一反映肯定是被截断了,必然是配置有问题。于是直接就去检查php的配置文件(当时也忘了nginx也有可能限制,但事实证明没有)。在php.ini里一通搜索,因为也不知道是什么配置限制了,就直接按关键字limit和max去搜,最后锁定目标 max_input_vars = 1000,百度查证果然是这货。当即将限制数值改大,重启php-fpm就解决了。
反思:事实上,通过这种改大限制的方式也是治标不治本,最好还是从源头上改变,提交数据时,将数据整合好,不要有大量表单的提交。