国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 語(yǔ)言 > PHP > 正文

php使用parse_url和parse_str解析URL

2024-09-04 11:42:48
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

本文主要向大家介紹了php中2個(gè)解析URL的方法(parse_url和parse_str),以及這2種方法的簡(jiǎn)介和用法,十分全面,推薦給有需要的小伙伴們。

PHP中有兩個(gè)方法可以用來(lái)解析URL,分別是parse_url和parse_str。

parse_url

解析 URL,返回其組成部分

mixed parse_url ( string $url [, int $component = -1 ] )

本函數(shù)解析一個(gè) URL 并返回一個(gè)關(guān)聯(lián)數(shù)組,包含在 URL 中出現(xiàn)的各種組成部分。

本函數(shù)不是用來(lái)驗(yàn)證給定 URL 的合法性的,只是將其分解為下面列出的部分。不完整的 URL 也被接受,parse_url() 會(huì)嘗試盡量正確地將其解析。

參數(shù)

url  要解析的 URL。無(wú)效字符將使用 _ 來(lái)替換。

component  指定 PHP_URL_SCHEME、 PHP_URL_HOST、 PHP_URL_PORT、 PHP_URL_USER、 PHP_URL_PASS、 PHP_URL_PATH、 PHP_URL_QUERY 或 PHP_URL_FRAGMENT 的其中一個(gè)來(lái)獲取 URL 中指定的部分的 string。 (除了指定為 PHP_URL_PORT 后,將返回一個(gè) integer 的值)。

返回值

對(duì)嚴(yán)重不合格的 URL,parse_url() 可能會(huì)返回 FALSE。

如果省略了 component 參數(shù),將返回一個(gè)關(guān)聯(lián)數(shù)組 array,在目前至少會(huì)有一個(gè)元素在該數(shù)組中,數(shù)組中可能的鍵有以下幾種:

scheme - 如 http

host

port

user

pass

path

query - 在問號(hào) ? 之后

fragment - 在散列符號(hào) # 之后

如果指定了 component 參數(shù), parse_url() 返回一個(gè) string (或在指定為 PHP_URL_PORT 時(shí)返回一個(gè) integer)而不是 array。如果 URL 中指定的組成部分不存在,將會(huì)返回 NULL。

實(shí)例代碼如下:

  1. <?php 
  2. $url = 'http://username:password@hostname/path?arg=value#anchor'
  3. print_r(parse_url($url)); 
  4. echo parse_url($url, PHP_URL_PATH); 
  5. ?> 

以上例程會(huì)輸出:

  1. Array 
  2.     [scheme] => http 
  3.     [host] => hostname 
  4.     [user] => username 
  5.     [pass] => password 
  6.     [path] => /path 
  7.     [query] => arg=value 
  8.     [fragment] => anchor 
  9. /path 

parse_str

將字符串解析成多個(gè)變量

void parse_str ( string $str [, array &$arr ] )

如果 str 是 URL 傳遞入的查詢字符串(query string),則將它解析為變量并設(shè)置到當(dāng)前作用域。

獲取當(dāng)前的 QUERY_STRING,你可以使用 $_SERVER['QUERY_STRING'] 變量。

參數(shù)

str  輸入的字符串。

arr  如果設(shè)置了第二個(gè)變量 arr,變量將會(huì)以數(shù)組元素的形式存入到這個(gè)數(shù)組,作為替代。

實(shí)例代碼如下:

  1. <?php 
  2. $str = "first=value&arr[]=foo+bar&arr[]=baz"
  3. parse_str($str); 
  4. echo $first;  // value 
  5. echo $arr[0]; // foo bar 
  6. echo $arr[1]; // baz 
  7. parse_str($str$output); 
  8. echo $output['first'];  // value 
  9. echo $output['arr'][0]; // foo bar 
  10. echo $output['arr'][1]; // baz 
  11. ?> 

前一段時(shí)間在讀php-resque的源碼,看到了在其中對(duì)這兩個(gè)的方法的應(yīng)用,感覺用的很好,用來(lái)解析redis鏈接的設(shè)置。

redis鏈接的格式是:redis://user:pass@host:port/db?option1=val1&option2=val2,是不是和URL一樣,所以用以上兩個(gè)方法很容易解析。

地址: https://github.com/chrisboulton/php-resque/blob/master/lib/Resque/Redis.php

代碼如下:

  1. /** 
  2.  * Parse a DSN string, which can have one of the following formats: 
  3.  * 
  4.  * - host:port 
  5.  * - redis://user:pass@host:port/db?option1=val1&option2=val2 
  6.  * - tcp://user:pass@host:port/db?option1=val1&option2=val2 
  7.  * 
  8.  * Note: the 'user' part of the DSN is not used. 
  9.  * 
  10.  * @param string $dsn A DSN string 
  11.  * @return array An array of DSN compotnents, with 'false' values for any unknown components. e.g. 
  12.  *               [host, port, db, user, pass, options] 
  13.  */ 
  14. public static function parseDsn($dsn
  15.     if ($dsn == '') { 
  16.         // Use a sensible default for an empty DNS string 
  17.         $dsn = 'redis://' . self::DEFAULT_HOST; 
  18.     } 
  19.     $parts = parse_url($dsn); 
  20.     // Check the URI scheme 
  21.     $validSchemes = array('redis''tcp'); 
  22.     if (isset($parts['scheme']) && ! in_array($parts['scheme'], $validSchemes)) { 
  23.         throw new /InvalidArgumentException("Invalid DSN. Supported schemes are " . implode(', '$validSchemes)); 
  24.     } 
  25.     // Allow simple 'hostname' format, which `parse_url` treats as a path, not host. 
  26.     if ( ! isset($parts['host']) && isset($parts['path'])) { 
  27.         $parts['host'] = $parts['path']; 
  28.         unset($parts['path']); 
  29.     } 
  30.     // Extract the port number as an integer 
  31.     $port = isset($parts['port']) ? intval($parts['port']) : self::DEFAULT_PORT; 
  32.     // Get the database from the 'path' part of the URI 
  33.     $database = false; 
  34.     if (isset($parts['path'])) { 
  35.         // Strip non-digit chars from path 
  36.         $database = intval(preg_replace('/[^0-9]/'''$parts['path'])); 
  37.     } 
  38.     // Extract any 'user' and 'pass' values 
  39.     $user = isset($parts['user']) ? $parts['user'] : false; 
  40.     $pass = isset($parts['pass']) ? $parts['pass'] : false; 
  41.     // Convert the query string into an associative array 
  42.     $options = array(); 
  43.     if (isset($parts['query'])) { 
  44.         // Parse the query string into an array 
  45.         parse_str($parts['query'], $options); 
  46.     } 
  47.     return array
  48.         $parts['host'], 
  49.         $port
  50.         $database
  51.         $user
  52.         $pass
  53.         $options
  54.     ); 

上面所述就是PHP解析URL的2種方法了,希望小伙伴們能夠喜歡。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 新建县| 绵竹市| 江川县| 县级市| 河源市| 兴山县| 抚顺县| 南靖县| 临潭县| 全南县| 高平市| 六枝特区| 冷水江市| 太谷县| 江陵县| 自治县| 兴海县| 前郭尔| 孙吴县| 马山县| 噶尔县| 青龙| 赫章县| 嵊州市| 昌乐县| 许昌县| 修文县| 远安县| 永安市| 宁陵县| 精河县| 滨海县| 永昌县| 永新县| 鹤壁市| 临海市| 新余市| 盘山县| 女性| 同德县| 剑川县|