esc_url()

URL 过滤

描述

主要用于 URL 过滤:

拒绝不是下面协议的 URL (defaulting to http, https, ftp, ftps, mailto, news, irc, gopher, nntp, feed, and telnet)
消除无效字符和删除危险字符。
将字符转换成 HTML 实体,并且将 & 和 单引号(’) 转换成数字实体:&#038, &#039。

用法

<?php esc_url( $url, $protocols, $_context ); ?>

参数

$url

(string) (必填) 将要被清理过滤的 URL

默认值: None

$protocols

(array) (可选) 可以接受协议的数组,如果没有设置,默认是:’http’, ‘https’, ‘ftp’, ‘ftps’, ‘mailto’, ‘news’, ‘irc’, ‘gopher’, ‘nntp’, ‘feed’, ‘telnet’。

默认值: null

$_context

(string) (可选) 如何返回 URL。

默认值: ‘display’

返回值

(string) 

The cleaned $url after the ‘esc_url‘ filter is applied. An empty string is returned if $url specifies a protocol other than those in $protocols, or if $url contains an empty string.

已经清理过滤的 URL

示例

<a href=“<?php echo esc_url( home_url( ‘/’ ) ); ?>“>Home</a>

注意

开发者可以通过 cleaned_url 这个 filter 接口对返回 $url 进行再次过滤。

源文件

esc_url() 函数的代码位于 wp-includes/formatting.php.

/**
* Checks and cleans a URL.
*
* A number of characters are removed from the URL. If the URL is for displaying
* (the default behaviour) ampersands are also replaced. The ‘clean_url’ filter
* is applied to the returned cleaned URL.
*
* @since 2.8.0
*
* @param string $url       The URL to be cleaned.
* @param array  $protocols Optional. An array of acceptable protocols.
*                     Defaults to return value of wp_allowed_protocols()
* @param string $_context  Private. Use esc_url_raw() for database usage.
* @return string The cleaned $url after the ‘clean_url’ filter is applied.
*/

function esc_url( $url, $protocols = null, $_context = ‘display’ ) {

$original_url = $url;

if ( ” == $url )

return $url;

$url = preg_replace(‘|[^a-z0-9-~+_.?#=!&;,/:%@$|*’()x80–xff]|i‘, ‘‘, $url);

if ( 0 !== stripos( $url, ‘mailto:‘ ) ) {

$strip = array(‘%0d‘, ‘%0a‘, ‘%0D‘, ‘%0A‘);

$url = _deep_replace($strip, $url);
}

$url = str_replace(‘;//’, ‘://’, $url);

/* If the URL doesn’t appear to contain a scheme, we

* presume it needs http:// appended (unless a relative
* link starting with /, # or ? or a php file).
*/

if ( strpos($url, ‘:’) === false && ! in_array( $url[0], array( ‘/’, ‘#’, ‘?’ ) ) &&

! preg_match(‘/^[a-z0-9-]+?.php/i’, $url) )

$url = ‘http://’ . $url;

// Replace ampersands and single quotes only when displaying.

if ( ‘display’ == $_context ) {

$url = wp_kses_normalize_entities( $url );

$url = str_replace( ‘&’, ‘&’, $url );

$url = str_replace( “‘”, ”‘, $url );

}

if ( ‘/‘ === $url[0] ) {

$good_protocol_url = $url;
} else {
if ( ! is_array( $protocols ) )
$protocols = wp_allowed_protocols();
$good_protocol_url = wp_kses_bad_protocol( $url, $protocols );
if ( strtolower( $good_protocol_url ) != strtolower( $url ) )

return ‘‘;

}
/**
* Filter a string cleaned and escaped for output as a URL.
*
* @since 2.3.0
*
* @param string $good_protocol_url The cleaned URL to be returned.
* @param string $original_url      The URL prior to cleaning.

* @param string $_context          If ‘display‘, replace ampersands and single quotes only.

*/

return apply_filters( ‘clean_url‘, $good_protocol_url, $original_url, $_context );

}
0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索