wp_parse_url

函数
wp_parse_url ( $url, $component = -1 )
参数
  • (string) $url The URL to parse.
    Required:
  • (int) $component The specific component to retrieve. Use one of the PHP predefined constants to specify which one. Defaults to -1 (= return all parts as an array).
    Required:
    Default: -1
返回值
  • (mixed) False on parse failure; Array of URL components on success; When a specific component has been requested: null if the component doesn't exist in the given URL; a string or - in the case of PHP_URL_PORT - integer when it does. See parse_url()'s return values.
定义位置
相关方法
wp_parse_strwp_parse_argswp_parse_listwp_parse_id_listwp_update_user
引入
4.4.0
弃用
-

wp_parse_url: 这个函数解析一个URL,并返回一个包含其组成部分的关联数组,如方案、主机、路径、查询和片段。

PHP的parse_url()函数的封装器,处理不同PHP版本的返回值的一致性。

PHP 5.4.7 扩展了 parse_url() 处理非绝对 URL 的权限,包括无模式和路径中含有””://””的相对 URL: 这个函数绕过了这些限制,在 PHP 5.2~5.4+ 上提供了一个标准输出。

其次,在不同的PHP版本中,对查询中含有””:””的无模式URL的处理是不一致的: 这个函数也是围绕这些差异而工作的。

function wp_parse_url( $url, $component = -1 ) {
	$to_unset = array();
	$url      = (string) $url;

	if ( '//' === substr( $url, 0, 2 ) ) {
		$to_unset[] = 'scheme';
		$url        = 'placeholder:' . $url;
	} elseif ( '/' === substr( $url, 0, 1 ) ) {
		$to_unset[] = 'scheme';
		$to_unset[] = 'host';
		$url        = 'placeholder://placeholder' . $url;
	}

	$parts = parse_url( $url );

	if ( false === $parts ) {
		// Parsing failure.
		return $parts;
	}

	// Remove the placeholder values.
	foreach ( $to_unset as $key ) {
		unset( $parts[ $key ] );
	}

	return _get_component_from_parsed_url_array( $parts, $component );
}

常见问题

FAQs
查看更多 >