我目前正在決議任何給定的 url,例如example.com/page/1或example.com/api/info/1,通過分解 URL:
$REQ = explode('/', $_SERVER['REQUEST_URI']);
array_shift($REQ);
$REQ = array_filter($REQ, function($value) { return $value !== ''; });]
然后像這樣訪問它在陣列中的元素:
if (count($REQ) > 1 && $REQ[0] == 'page' && $REQ[1] == '1'){
\\ show page 1
}
但是我如何處理(并以相同的方式通過陣列訪問)一個還包含 GET 元素的 url,例如example.com/page?id=1or example.com/api/info?=hello?
我正在使用 nginx 并嘗試如下檔案:
location / {
index index.php;
try_files $uri /index.php?$query_string;
}
uj5u.com熱心網友回復:
您也可以按函式決議 URL 以parse_url獲取查詢引數,您可以使用parse_str函式并提取所有查詢引數。
$url = 'https://example.com/api/info?param1=hello¶m2=wrold';
$url_parts = parse_url($url);
var_dump($url_parts);
parse_str($url_parts['query'], $query_params);
var_dump($query_params);
輸出:
array(4) {
["scheme"]=>
string(5) "https"
["host"]=>
string(11) "example.com"
["path"]=>
string(9) "/api/info"
["query"]=>
string(25) "param1=hello¶m2=wrold"
}
array(2) {
["param1"]=>
string(5) "hello"
["param2"]=>
string(5) "wrold"
}
轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/428602.html
上一篇:如何在nginx入口中捕獲子域
