當一個表單提交給 PHP 腳本時,表單中的信息會自動在腳本中可用。有幾個方法訪問此信息,例如:
示例 #1 一個簡單的 HTML 表單
<form action="foo.php" method="POST"> Name: <input type="text" name="username"><br /> Email: <input type="text" name="email"><br /> <input type="submit" name="submit" value="Submit me!" /> </form>
只有兩種方法可以訪問 HTML 表單中的數(shù)據(jù)。 以下列出了當前有效的方法:
示例 #2 從一個簡單的 POST HTML 表單訪問數(shù)據(jù)
<?php
echo $_POST['username'];
echo $_REQUEST['username'];
?>
使用 GET 表單也類似,只不過要用適當?shù)?GET 預(yù)定義變量。GET
也適用于
QUERY_STRING
(URL
中在“?”之后的信息)。因此,舉例說,http://www.example.com/test.php?id=3
包含有可用 $_GET['id']
來訪問的 GET 數(shù)據(jù)。參見
$_REQUEST。
注意:
變量名中的點和空格被轉(zhuǎn)換成下劃線。例如
<input name="a.b" />
變成了$_REQUEST["a_b"]
。
PHP 也懂得表單變量上下文中的數(shù)組(參見相關(guān)常見問題)。例如可以將相關(guān)的變量編成組,或者用此特性從多選輸入框中取得值。例如,將一個表單 POST 給自己并在提交時顯示數(shù)據(jù):
示例 #3 更復(fù)雜的表單變量
<?php
if (isset($_POST['action']) && $_POST['action'] == 'submitted') {
echo '<pre>';
print_r($_POST);
echo '<a href="'. $_SERVER['PHP_SELF'] .'">Please try again</a>';
echo '</pre>';
} else {
?>
<form action="<?php echo $_SERVER['PHP_SELF']; ?>" method="post">
Name: <input type="text" name="personal[name]"><br />
Email: <input type="text" name="personal[email]"><br />
Beer: <br>
<select multiple name="beer[]">
<option value="warthog">Warthog</option>
<option value="guinness">Guinness</option>
<option value="stuttgarter">Stuttgarter Schwabenbr</option>
</select><br />
<input type="hidden" name="action" value="submitted" />
<input type="submit" name="submit" value="submit me!" />
</form>
<?php
}
?>
注意: If an external variable name begins with a valid array syntax, trailing characters are silently ignored. For example,
<input name="foo[bar]baz">
becomes$_REQUEST['foo']['bar']
.
當提交表單時,可以用一幅圖像代替標準的提交按鈕,用類似這樣的標記:
<input type="image" src="image.gif" name="sub" />
當用戶點擊到圖像中的某處時,相應(yīng)的表單會被傳送到服務(wù)器,并加上兩個變量 sub_x 和 sub_y。它們包含了用戶點擊圖像的坐標。有經(jīng)驗的用戶可能會注意到被瀏覽器發(fā)送的實際變量名包含的是一個點而不是下劃線(即 sub.x 和 sub.y),但 PHP 自動將點轉(zhuǎn)換成了下劃線。
PHP 透明地支持 ? RFC 6265定義中的 HTTP cookies。Cookies 是一種在遠端瀏覽器端存儲數(shù)據(jù)并能追蹤或識別再次訪問的用戶的機制??梢杂? setcookie() 函數(shù)設(shè)定 cookies。Cookies 是 HTTP 信息頭中的一部分,因此 SetCookie 函數(shù)必須在向瀏覽器發(fā)送任何輸出之前調(diào)用。對于 header() 函數(shù)也有同樣的限制。Cookie 數(shù)據(jù)會在相應(yīng)的 cookie 數(shù)據(jù)數(shù)組中可用,例如 $_COOKIE 和 $_REQUEST。更多細節(jié)和例子見 setcookie() 手冊頁面。
注意: As of PHP 7.2.34, 7.3.23 and 7.4.11, respectively, the names of incoming cookies are no longer url-decoded for security reasons.
如果要將多個值賦給一個 cookie 變量,必須將其賦成數(shù)組。例如:
<?php
setcookie("MyCookie[foo]", 'Testing 1', time()+3600);
setcookie("MyCookie[bar]", 'Testing 2', time()+3600);
?>
這將會建立兩個單獨的 cookie,盡管 MyCookie 在腳本中是一個單一的數(shù)組。如果想在僅僅一個 cookie 中設(shè)定多個值,考慮先在值上使用 serialize() 或 explode()。
注意在瀏覽器中一個 cookie 會替換掉上一個同名的 cookie,除非路徑或者域不同。因此對于購物車程序可以保留一個計數(shù)器并一起傳遞,例如:
示例 #4 一個 setcookie() 的示例
<?php
if (isset($_COOKIE['count'])) {
$count = $_COOKIE['count'] + 1;
} else {
$count = 1;
}
setcookie('count', $count, time()+3600);
setcookie("Cart[$count]", $item, time()+3600);
?>
通常,PHP 不會改變傳遞給腳本中的變量名。然而應(yīng)該注意到點(句號)不是 PHP 變量名中的合法字符。至于原因,看看:
<?php
$varname.ext; /* 非法變量名 */
?>
出于此原因,要注意 PHP 將會自動將變量名中的點替換成下劃線。
因為 PHP 會判斷變量類型并在需要時進行轉(zhuǎn)換(通常情況下),因此在某一時刻給定的變量是何種類型并不明顯。PHP 包括幾個函數(shù)可以判斷變量的類型,例如:gettype(),is_array(),is_float(),is_int(),is_object() 和 is_string()。參見類型一章。
HTTP being a text protocol, most, if not all, content that comes in Superglobal arrays, like $_POST and $_GET will remain as strings. PHP will not try to convert values to a specific type. In the example below, $_GET["var1"] will contain the string "null" and $_GET["var2"], the string "123".
/index.php?var1=null&var2=123
版本 | 說明 |
---|---|
7.2.34, 7.3.23, 7.4.11 | The names of incoming cookies are no longer url-decoded for security reasons. |