get_oembed_response_data_for_url

函数
get_oembed_response_data_for_url ( $url, $args )
参数
  • (string) $url The URL that should be inspected for discovery `<link>` tags.
    Required:
  • (array) $args oEmbed remote get arguments.
    Required:
返回值
  • (object|false) oEmbed response data if the URL does belong to the current site. False otherwise.
定义位置
相关方法
get_oembed_response_dataget_oembed_response_data_richget_oembed_endpoint_urlget_comment_author_url_response_to_rss
引入
5.0.0
弃用
-

get_oembed_response_data_for_url函数用于检索特定URL的oEmbed响应数据,并将结果缓存起来: 这个函数可以通过避免对oEmbed提供者的不必要的请求来提高性能。

为一个给定的URL检索oEmbed响应数据。

function get_oembed_response_data_for_url( $url, $args ) {
	$switched_blog = false;

	if ( is_multisite() ) {
		$url_parts = wp_parse_args(
			wp_parse_url( $url ),
			array(
				'host' => '',
				'path' => '/',
			)
		);

		$qv = array(
			'domain'                 => $url_parts['host'],
			'path'                   => '/',
			'update_site_meta_cache' => false,
		);

		// In case of subdirectory configs, set the path.
		if ( ! is_subdomain_install() ) {
			$path = explode( '/', ltrim( $url_parts['path'], '/' ) );
			$path = reset( $path );

			if ( $path ) {
				$qv['path'] = get_network()->path . $path . '/';
			}
		}

		$sites = get_sites( $qv );
		$site  = reset( $sites );

		// Do not allow embeds for deleted/archived/spam sites.
		if ( ! empty( $site->deleted ) || ! empty( $site->spam ) || ! empty( $site->archived ) ) {
			return false;
		}

		if ( $site && get_current_blog_id() !== (int) $site->blog_id ) {
			switch_to_blog( $site->blog_id );
			$switched_blog = true;
		}
	}

	$post_id = url_to_postid( $url );

	/** This filter is documented in wp-includes/class-wp-oembed-controller.php */
	$post_id = apply_filters( 'oembed_request_post_id', $post_id, $url );

	if ( ! $post_id ) {
		if ( $switched_blog ) {
			restore_current_blog();
		}

		return false;
	}

	$width = isset( $args['width'] ) ? $args['width'] : 0;

	$data = get_oembed_response_data( $post_id, $width );

	if ( $switched_blog ) {
		restore_current_blog();
	}

	return $data ? (object) $data : false;
}

常见问题

FAQs
查看更多 >