|
form.html
復(fù)制代碼 代碼如下:
<form action="action.php" method="post">
<input type="text" name="username">
<input type="password" name="password">
<input type="submit">
在action.php中只要使用extract()函數(shù)將$_POST全局?jǐn)?shù)據(jù)解開:
action.php
復(fù)制代碼 代碼如下:
<?php
extract($_POST);
//相當(dāng)于$username = $_POST['username'];
//$password = $_POST['password'];
?>
是不是很方便呢?呵呵,下面是php手冊(cè)里的詳細(xì)解釋:
extract
(php 4, php 5)
extract ― 從數(shù)組中將變量導(dǎo)入到當(dāng)前的符號(hào)表
說明
int extract ( array $var_array [, int $extract_type [, string $prefix ]] )
本函數(shù)用來將變量從數(shù)組中導(dǎo)入到當(dāng)前的符號(hào)表中。接受結(jié)合數(shù)組 var_array 作為參數(shù)并將鍵名當(dāng)作變量名,值作為變量的值。對(duì)每個(gè)鍵/值對(duì)都會(huì)在當(dāng)前的符號(hào)表中建立變量,并受到 extract_type 和 prefix 參數(shù)的影響。
Note: 自版本 4.0.5 起本函數(shù)返回被提取的變量數(shù)目。
Note: EXTR_IF_EXISTS 和 EXTR_PREFIX_IF_EXISTS 是版本 4.2.0 中引進(jìn)的。
Note: EXTR_REFS 是版本 4.3.0 中引進(jìn)的。
extract() 檢查每個(gè)鍵名看是否可以作為一個(gè)合法的變量名,同時(shí)也檢查和符號(hào)表中已有的變量名的沖突。對(duì)待非法/數(shù)字和沖突的鍵名的方法將根據(jù) extract_type 參數(shù)決定。可以是以下值之一:
EXTR_OVERWRITE
如果有沖突,覆蓋已有的變量。
EXTR_SKIP
如果有沖突,不覆蓋已有的變量。
EXTR_PREFIX_SAME
如果有沖突,在變量名前加上前綴 prefix 。
EXTR_PREFIX_ALL
給所有變量名加上前綴 prefix 。自 php 4.0.5 起這也包括了對(duì)數(shù)字索引的處理。
EXTR_PREFIX_INVALID
僅在非法/數(shù)字的變量名前加上前綴 prefix 。本標(biāo)記是 php 4.0.5 新加的。
EXTR_IF_EXISTS
僅在當(dāng)前符號(hào)表中已有同名變量時(shí),覆蓋它們的值。其它的都不處理。可以用在已經(jīng)定義了一組合法的變量,然后要從一個(gè)數(shù)組例如 $_REQUEST 中提取值覆蓋這些變量的場(chǎng)合。本標(biāo)記是 php 4.2.0 新加的。
EXTR_PREFIX_IF_EXISTS
僅在當(dāng)前符號(hào)表中已有同名變量時(shí),建立附加了前綴的變量名,其它的都不處理。本標(biāo)記是 php 4.2.0 新加的。
EXTR_REFS
將變量作為引用提取。這有力地表明了導(dǎo)入的變量仍然引用了 var_array 參數(shù)的值。可以單獨(dú)使用這個(gè)標(biāo)志或者在 extract_type 中用 OR 與其它任何標(biāo)志結(jié)合使用。本標(biāo)記是 php 4.3.0 新加的。
如果沒有指定 extract_type ,則被假定為 EXTR_OVERWRITE。
注意 prefix 僅在 extract_type 的值是 EXTR_PREFIX_SAME,EXTR_PREFIX_ALL,EXTR_PREFIX_INVALID 或 EXTR_PREFIX_IF_EXISTS 時(shí)需要。如果附加了前綴后的結(jié)果不是合法的變量名,將不會(huì)導(dǎo)入到符號(hào)表中。前綴和數(shù)組鍵名之間會(huì)自動(dòng)加上一個(gè)下劃線。
extract() 返回成功導(dǎo)入到符號(hào)表中的變量數(shù)目。
Warning
不要對(duì)不能信任的數(shù)據(jù)使用 extract(),例如用戶的輸入($_GET,…)。如果這樣做,舉例說,要臨時(shí)運(yùn)行依賴于 register_globals 的老代碼,要確保使用不會(huì)覆蓋的 extract_type 值,例如 EXTR_SKIP,并且要留意應(yīng)該按照 php.ini 中由 variables_order 定義的順序來提取。
extract() 的一種可能用法是將 wddx_deserialize() 返回的結(jié)合數(shù)組中的內(nèi)容導(dǎo)入到符號(hào)表變量中去。
Example#1 extract() 例子
復(fù)制代碼 代碼如下:
<?php
/* 假定 $var_array 是 wddx_deserialize 返回的數(shù)組*/
$size = “l(fā)arge”;
$var_array = array(”color” => “blue”,
“size” => “medium”,
“shape” => “sphere”);
extract($var_array, EXTR_PREFIX_SAME, “wddx”);
echo “$color, $size, $shape, $wddx_size/n”;
?>
上例將輸出:
blue, large, sphere, medium
$size 沒有被覆蓋,因?yàn)橹付?EXTR_PREFIX_SAME,這使得 $wddx_size 被建立。如果指定了 EXTR_SKIP,則 $wddx_size 也不會(huì)被建立。EXTR_OVERWRITE 將使 $size 的值為“medium”,EXTR_PREFIX_ALL 將建立新變量 $wddx_color,$wddx_size 和 $wddx_shape。
必須使用關(guān)聯(lián)數(shù)組,數(shù)字索引的數(shù)組將不會(huì)產(chǎn)生結(jié)果,除非用了 EXTR_PREFIX_ALL 或者 EXTR_PREFIX_INVALID。
php技術(shù):PHP中extract()函數(shù)的妙用分析,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。