PHP中接收外部參數的方式有哪些
本篇文章為大家介紹PHP中接收外部參數的方式。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有幫助。
對PHP這樣一個web語言來說,接參是非常重要的一個能力。畢竟從前端表單或非同步請求傳遞上來的資料都要取得到才能進行正常的互動展示。當然,這也是所有能夠進行web開發的語言的必備能力。今天我們就來看看PHP各種各樣的接參形式。
首先,我們要準備一個靜態頁面,就像下面這個一樣,它提供了一個表單,同時url裡還帶有一個GET參數:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <form action="?show=1" method="post"> 姓名:<input type="text" name="name"/><br /> 电话:<input type="text" name="tel"/><br/> 地址(省):<input type="text" name="address.prov"/><br/> 地址(市):<input type="text" name="address city"/><br/> 兴趣1:<input type="text" name="interest[]"/><br/> 兴趣2:<input type="text" name="interest[]"/><br/> 兴趣3:<input type="text" name="interest[]"/><br/> 学历1:<input type="text" name="edu[one]"/><br/> 学历2:<input type="text" name="edu[two]"/><br/> <input type="submit" value="提交" > </form> </body> </html>
#正常的$ _GET、$_POST方式
// 正常的GET、POST echo $_GET['show'], '<br/>'; // 1 echo $_POST['name'], '<br/>'; // 提交的内容
這是最基礎的也是最直接的接參方式,GET參數透過$_GET 獲取,POST參數透過$_POST 獲取,互相都不干擾。
正常的$_REQUEST方式
// 使用REQUEST echo $_REQUEST['show'], '<br/>'; // 1 echo $_REQUEST['tel'], '<br/>'; // 提交的内容
$_REQUEST 則是取得所有請求中的參數,不包含上傳檔案。也就是說,它包含了 $_GET 、 $_POST 以及 $_COOKIE(需要配置,預設不包含) 這三個接參變數中的所有內容。這裡要注意的一點是,PHP5.3以後, $_REQUEST 接受的參數變數內容由php.ini 檔案中的request_order 指定,預設情況下這個配置參數的值是GP 也就是GET 和POST ,並沒有COOKIE ,想要COOKIE 的話需要修改這裡新增一個C就可以了。
如果 $_GET 、 $_POST 中有同名的內容呢? $_REQUEST 展示的順序也是根據這配置參數的順序來的,從左到右,後面的覆蓋前面的,例如你配置的是GP 那麼參數覆蓋的順序是: POST > GET,最終顯示的就是POST 中的內容。
register_globals問題
// register_globals 如果打开 echo $name, '<br/>'; // 提交的内容 echo $tel, '<br/>'; // 提交的内容
這是一個不安全的配置,也是在 php.ini 檔案中進行配置的。它的作用就是將請求來的參數直接轉成變量,有全域變量污染的問題,不要打開! ! !現在的 php.ini 檔案中基本上都是預設關閉的。
import_request_variables
// import_request_variables 抱歉,5.4之后已经取消了 import_request_variables('pg', 'pg_'); echo $pg_show, '<br/>'; echo $pg_name, '<br/>';
這個函數是手動將指定的參數變數裡面的內容註冊為全域變量,同樣的,它也在5.4之後被取消的,這樣的函數都會有風險,我們來了解曾經有過這樣一個函數即可。
extract
extract($_POST, EXTR_PREFIX_ALL, 'ex'); echo $ex_name, '<br/>'; // 提交的内容 echo $ex_tel, '<br/>'; // 提交的内容
extract 是目前可以取代上面兩種參數轉變量的方式中目前依然支援的。它是由我們自己來控制對已存在變數的覆蓋的,也就是第二個參數,這樣在可控的環境下可以極大地避免污染全局變數的問題,當然前提還是我們自己要確定使用它,具體內容可以自行找找文件參考!
參數名稱中的.和空格
// 参数名中的.和空格 echo $_REQUEST['address_prov'], '<br/>'; // 提交的内容 echo $_REQUEST['address_city'], '<br/>'; // 提交的内容
表單提交的 input 的 name 中如果包含 . 或 空格 ,將直接轉換成 下劃線 。不過我們在前端命名中也不建議使用 . 或 空格 ,需要的時候直接就使用 下劃線 就好了,前後端不要造成歧義。
參數名稱中的[]
// 参数名中的[] print_r($_REQUEST['interest']); // Array (v,....) echo '<br />'; print_r($_REQUEST['edu']); // Array (k/v,....)
當表單提交的input 的name 是陣列形式的,也就是"interest[]" 或"edu[one] " 當這種形式時,我們接收到的參數預設就會成為一個陣列形式的內容。
高大上的php://input
// php://input $content = file_get_contents('php://input'); print_r($content); //name=xxx&.....
最後就是現在介面開發中常會使用的 php://input 形式接參。一般是因為安全或參數欄位較多的情況下,前端透過 Body Raw 的形式直接傳遞一整段的 Body 內容過來。這時候就只能用這種形式取得到了,這個 Body Raw 的原始內容一般會是一整段的文字,也有可能是進行過一些加密處理的內容,格式可以自己定義。而面對一般表單,我們將會接收到的也是原始的表單內容,就像上面的 name=xxx&tel=xxx&.... 這樣的內容。
要注意的是 enctype="multipart/form-data" 時它是無法取得內容的。同時,這種方式也是代替 $HTTP_RAW_POST_DATA 全域變數的,不要再使用淘汰的能力了哦,儘早更新新版本的PHP使用新的語法特性哦!
總結
隨便一整理就發現原來簡簡單單的一個接參就有這麼多形式和需要注意的地方,還真是大開眼界。還是那句話,學無止盡,繼續深入的鑽研早晚你也會成為大牛!
測試程式碼:
https://github.com/zhangyue0503/dev-blog/blob/master/php/202002/source/%E5%8F%98%E7%9D%80%E8%8A%B1%E6%A0%B7%E6%9D%A5%E6%8E%A5%E5%8F%82%EF%BC%8CPHP%E4%B8%AD%E6%8E%A5%E6%94%B6%E5%A4%96%E9%83%A8%E5%8F%82%E6%95%B0%E7%9A%84%E6%96%B9%E5%BC%8F.php
推薦學習:php影片教學
以上是PHP中接收外部參數的方式有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

字符串是由字符組成的序列,包括字母、數字和符號。本教程將學習如何使用不同的方法在PHP中計算給定字符串中元音的數量。英語中的元音是a、e、i、o、u,它們可以是大寫或小寫。 什麼是元音? 元音是代表特定語音的字母字符。英語中共有五個元音,包括大寫和小寫: a, e, i, o, u 示例 1 輸入:字符串 = "Tutorialspoint" 輸出:6 解釋 字符串 "Tutorialspoint" 中的元音是 u、o、i、a、o、i。總共有 6 個元

靜態綁定(static::)在PHP中實現晚期靜態綁定(LSB),允許在靜態上下文中引用調用類而非定義類。 1)解析過程在運行時進行,2)在繼承關係中向上查找調用類,3)可能帶來性能開銷。

PHP的魔法方法有哪些? PHP的魔法方法包括:1.\_\_construct,用於初始化對象;2.\_\_destruct,用於清理資源;3.\_\_call,處理不存在的方法調用;4.\_\_get,實現動態屬性訪問;5.\_\_set,實現動態屬性設置。這些方法在特定情況下自動調用,提升代碼的靈活性和效率。

PHP和Python各有優勢,選擇依據項目需求。 1.PHP適合web開發,尤其快速開發和維護網站。 2.Python適用於數據科學、機器學習和人工智能,語法簡潔,適合初學者。

PHP在電子商務、內容管理系統和API開發中廣泛應用。 1)電子商務:用於購物車功能和支付處理。 2)內容管理系統:用於動態內容生成和用戶管理。 3)API開發:用於RESTfulAPI開發和API安全性。通過性能優化和最佳實踐,PHP應用的效率和可維護性得以提升。

PHP是一種廣泛應用於服務器端的腳本語言,特別適合web開發。 1.PHP可以嵌入HTML,處理HTTP請求和響應,支持多種數據庫。 2.PHP用於生成動態網頁內容,處理表單數據,訪問數據庫等,具有強大的社區支持和開源資源。 3.PHP是解釋型語言,執行過程包括詞法分析、語法分析、編譯和執行。 4.PHP可以與MySQL結合用於用戶註冊系統等高級應用。 5.調試PHP時,可使用error_reporting()和var_dump()等函數。 6.優化PHP代碼可通過緩存機制、優化數據庫查詢和使用內置函數。 7

PHP仍然具有活力,其在現代編程領域中依然佔據重要地位。 1)PHP的簡單易學和強大社區支持使其在Web開發中廣泛應用;2)其靈活性和穩定性使其在處理Web表單、數據庫操作和文件處理等方面表現出色;3)PHP不斷進化和優化,適用於初學者和經驗豐富的開發者。
