wp_get_canonical_url()WP 4.6.0

Получает канонический URL записи (поста).

Для страниц пагинации создается отдельная ссылка. Например для страницы пагинации комментариев записи она будет выглядеть так: http://example.com/postname/comment-page-2.

Работает на основе: get_permalink()
Основа для: rel_canonical()
1 раз — 0.000338 сек (быстро) | 50000 раз — 3.05 сек (быстро) | PHP 7.0.8, WP 4.6
Хуки из функции

Возвращает

Строку|false. Канонический URL или false, если запись не существует или еще не опубликована.

Использование

wp_get_canonical_url( $post );
$post(число/WP_Post)
ID или объект записи.
По умолчанию: null (текущая запись)

Примеры

-1

#1 Выведем канонический URL записи 803

echo wp_get_canonical_url( 803 );
// выведет: http://wp-kama.ru/id_803/pishem-pravilnyiy-robotstxt-dlya-wordpress.html

Список изменений

С версии 4.6.0 Введена.

Код wp_get_canonical_url() WP 6.8.1

function wp_get_canonical_url( $post = null ) {
	$post = get_post( $post );

	if ( ! $post ) {
		return false;
	}

	if ( 'publish' !== $post->post_status ) {
		return false;
	}

	$canonical_url = get_permalink( $post );

	// If a canonical is being generated for the current page, make sure it has pagination if needed.
	if ( get_queried_object_id() === $post->ID ) {
		$page = get_query_var( 'page', 0 );
		if ( $page >= 2 ) {
			if ( ! get_option( 'permalink_structure' ) ) {
				$canonical_url = add_query_arg( 'page', $page, $canonical_url );
			} else {
				$canonical_url = trailingslashit( $canonical_url ) . user_trailingslashit( $page, 'single_paged' );
			}
		}

		$cpage = get_query_var( 'cpage', 0 );
		if ( $cpage ) {
			$canonical_url = get_comments_pagenum_link( $cpage );
		}
	}

	/**
	 * Filters the canonical URL for a post.
	 *
	 * @since 4.6.0
	 *
	 * @param string  $canonical_url The post's canonical URL.
	 * @param WP_Post $post          Post object.
	 */
	return apply_filters( 'get_canonical_url', $canonical_url, $post );
}