wp_check_invalid_utf8

函数
wp_check_invalid_utf8 ( $string, $strip = false )
参数
  • (string) $string The text which is to be checked.
    Required:
  • (bool) $strip Optional. Whether to attempt to strip out invalid UTF8. Default false.
    Required:
    Default: false
返回值
  • (string) The checked text.
定义位置
相关方法
wp_opcache_invalidatewp_cache_initwp_check_locked_postswp_check_filetype_and_extwp_checkdate
引入
2.8.0
弃用
-

wp_check_invalid_utf8: 这个函数用来检查一个字符串是否包含无效的UTF-8字符。它可以用来防止无效的字符在网站上显示。

检查字符串中是否有无效的UTF8。

function wp_check_invalid_utf8( $string, $strip = false ) {
	$string = (string) $string;

	if ( 0 === strlen( $string ) ) {
		return '';
	}

	// Store the site charset as a static to avoid multiple calls to get_option().
	static $is_utf8 = null;
	if ( ! isset( $is_utf8 ) ) {
		$is_utf8 = in_array( get_option( 'blog_charset' ), array( 'utf8', 'utf-8', 'UTF8', 'UTF-8' ), true );
	}
	if ( ! $is_utf8 ) {
		return $string;
	}

	// Check for support for utf8 in the installed PCRE library once and store the result in a static.
	static $utf8_pcre = null;
	if ( ! isset( $utf8_pcre ) ) {
		// phpcs:ignore WordPress.PHP.NoSilencedErrors.Discouraged
		$utf8_pcre = @preg_match( '/^./u', 'a' );
	}
	// We can't demand utf8 in the PCRE installation, so just return the string in those cases.
	if ( ! $utf8_pcre ) {
		return $string;
	}

	// phpcs:ignore WordPress.PHP.NoSilencedErrors.Discouraged -- preg_match fails when it encounters invalid UTF8 in $string.
	if ( 1 === @preg_match( '/^./us', $string ) ) {
		return $string;
	}

	// Attempt to strip the bad chars if requested (not recommended).
	if ( $strip && function_exists( 'iconv' ) ) {
		return iconv( 'utf-8', 'utf-8', $string );
	}

	return '';
}

常见问题

FAQs
查看更多 >