PHP变量解析顺序variables_order

转载自:http://blog.csdn.net/knight0450/article/details/4291556

故事从一个有点诡异的BUG开始,后台一个使用频率不是很高的广告提交功能有时候会莫名其妙的发生提交的链接网址出错的问题。
由于提交后并没有告知该次提交的链接URL,所以这个BUG一直活到了今天。
然而并不是每一次提交都会出现这个BUG,几次测试后发现只有在连续多次提交时发生。
由于提交的表单比较复杂,分几部分录入,于是怀疑在中间环节发生错误。
排错的过程先是在各个过程中var_dump($_REQUEST),于是连续第二次提交时找到出错环节,在第一个表单提交到第二个表单的过程中,
$_REQUEST数组发生改变。到这里,我们有必要再看一下$_REQUEST数组:
手册上讲包含经由 GET,POST 和 COOKIE 机制提交至脚本的变量,因此该数组并不值得信任。
以此将var_dump($_REQUEST)分解成var_dump($_POST),var_dump($_GET),var_dump($_COOKIE),问题就比较清晰了,
原来为了便于在多个页面表单间保存值,试用了COOKIE,虽然没有设置expire项的情况下SESSION结束时COOKIE变销毁,
但是如果在一次会话中连续提交多个广告,表单POST的值变会被之前保存在COOKIE的值覆盖,而之所以只有部分出错,
在于保存到COOKIE的时候COOKIE变量名都加了前缀,除了url这个变量还是使用相同的变量名。
问题找到了,但是又有新的疑问,相同的变量名,为什么是COOKIE覆盖了POST而不是相反呢?
于是终于要来到标题讲的variables_order设置项了,PHP.ini中原文如下:

This directive describes the order in which PHP registers GET, POST, Cookie,
Environment and Built-in variables (G, P, C, E & S respectively, often
referred to as EGPCS or GPC). Registration is done from left to right, newer
values override older values.

意思是该设置描述PHP解析变量顺序,包括$_GET,$_POST,$_COOKIE,$_ENV ,$_SERVER 数组,
解析顺序从左到右,后解析新值覆盖旧值。默认设定为EGPCS(Environment,GET,POST,Cookie,Server)。
如果将其设为“GP”,会导致 PHP 完全忽略环境变量,cookies 和 server 变量,并用 POST 方法的变量覆盖 GET 方法的同名变量。

结论:就像手册上讲的,$_REQUEST是个并不值得信任的数组。为了尽量避免类似问题,在获取提交值是应明确使用$_POST或$_GET数组。
特殊情况下可以通过调整variables_order设置,使自己总是能得到想要获取的提交数据。

时间: 2024-10-11 16:50:05

PHP变量解析顺序variables_order的相关文章

javascript的解析顺序和变量作用域

一.变量的作用域 1.全局变量 在代码中任何地方都能够访问得到的变量,拥有全局的作用域. A.最外层函数外面定义的变量. B.没有定义直接赋值的变量,拥有全局属性. 2.局部变量 只能在固定的代码片段(函数片段中)中访问得到. A.函数内部定义的变量,就是局部变量. B.参数也是局部变量. 二.javascript预解析顺序 一.<Script></script>块依次解析. 二.解析代码运行的环境. 三.对标识符(关键字)(var function )进行解析,解析到相应的环境下

JavaScript解析顺序和变量作用域

javascript解析顺序和变量作用域 一.变量的作用域 1.全局变量:在代码中任何地方都能够访问得到的变量,拥有全局的作用域.        A.最外层函数外面定义的变量.        B.没有定义直接赋值的变量,拥有全局属性. 2.局部变量:只能在固定的代码片段(函数片段中)中访问得到.        A.函数内部定义的变量,就是局部变量.        B.参数也是局部变量.     二.javascript预解析顺序    1.<Script></script>块依次解

javascript的解析顺序

一.javascript的解析顺序 我们大家所理解的代码的执行顺序都是从上到下的,但是实际上确不是这样的.我们看一下下面的代码. 1 alert(a);2 var a = 1;如果执行顺序是从上到下的,在上面弹出一个a,浏览器会认为从上到下执行的,那么当它alert(a)的时候,他就会发现没有这个东西,那么他就会报错,但是实际上他弹出来的结果是undefined.返回值是undefined说明a没有被定义也就是没有赋值.下面我来讲解一下javascript的解析顺序. 1.ES5中有声明意义的关

步步深入:MySQL架构总览-&gt;查询执行流程-&gt;SQL解析顺序

前言: 一直是想知道一条SQL语句是怎么被执行的,它执行的顺序是怎样的,然后查看总结各方资料,就有了下面这一篇博文了. 本文将从MySQL总体架构--->查询执行流程--->语句执行顺序来探讨一下其中的知识. 一.MySQL架构总览: 架构最好看图,再配上必要的说明文字. 下图根据参考书籍中一图为原本,再在其上添加上了自己的理解. 从上图中我们可以看到,整个架构分为两层,上层是MySQLD的被称为的‘SQL Layer’,下层是各种各样对上提供接口的存储引擎,被称为‘Storage Engin

MySQL架构总览-&gt;查询执行流程-&gt;SQL解析顺序

前言: 一直是想知道一条SQL语句是怎么被执行的,它执行的顺序是怎样的,然后查看总结各方资料,就有了下面这一篇博文了. 本文将从MySQL总体架构--->查询执行流程--->语句执行顺序来探讨一下其中的知识. 一.MySQL架构总览: 架构最好看图,再配上必要的说明文字. 下图根据参考书籍中一图为原本,再在其上添加上了自己的理解. 从上图中我们可以看到,整个架构分为两层,上层是MySQLD的被称为的'SQL Layer',下层是各种各样对上提供接口的存储引擎,被称为'Storage Engin

OK335xS U-boot 环境变量解析

/************************************************************************************************** * OK335xS U-boot 环境变量解析 * 声明: * 本文主要是为了知道OK335xS U-boot环境变量设置.如何选择启动方式等等内容. * * 2015-9-28 晴 深圳 南山平山村 曾剑锋 *********************************************

关于函数的解析顺序

<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>函数的解析顺序</title> </head> <body> <script type="text/javascript"> function f(){ return 1; } alert(f()); //4,说明第一个函数被第四个函数覆盖 v

调整static变量初始化顺序的一个办法

// wrap the LaunchDir variable in a function to work around static/global initialization order static FString& GetWrappedLaunchDir() { static FString LaunchDir; return LaunchDir; } 在ue4中看到这么一段代码,注释有点意思 不同cpp文件里的全局static变量初始化顺序是不可控的 FString显然会依赖很多内存分配

java 静态变量初始化顺序

public class Elvis { public static final Elvis INSTANCE = new Elvis(); private final int beltSize; private static final int CURRENT_YEAR = Calendar.getInstance().get(Calendar.YEAR); private Elvis() { beltSize = CURRENT_YEAR - 1930; } public int beltS