Мы используем WordPress и хотели бы связать amp с amp, если на связанной странице есть версия amp. У нас усилитель структурирован так: test.de/test/amp
К сожалению, этот код в моем functions.php не применяется к ссылкам, жестко закодированным внутри содержимого публикации. Что я должен изменить, чтобы он работал для каждой внутренней ссылки:
add_filter( 'post_link', function( $url, $post ) {
static $recursing = false;
if ( $recursing ) {
return $url;
}
$recursing = true;
if ( ! function_exists( 'post_supports_amp' ) || ! post_supports_amp( $post ) ) {
return $url;
}
if ( function_exists( 'is_amp_endpoint' ) && is_amp_endpoint() ) {
$url = amp_get_permalink( $post->ID );
}
$recursing = false;
return $url;
}, 10, 2 );
В настоящее время это относится и к канонической ссылке, что очень плохо для SEO. Как это предотвратить?
Добавьте эти функции в файл functions.php вашей темы.
/* post link filter */
add_filter( 'post_link', 'change_amp_url', 10, 2 );
function change_amp_url( $url, $postobj ) {
static $recursing = false;
if ( $recursing ) {
return $url;
}
$recursing = true;
if ( function_exists( 'is_amp_endpoint' ) && is_amp_endpoint() ) {
if ( function_exists( 'post_supports_amp' ) && post_supports_amp( $postobj ) ) {
$url = amp_get_permalink( $postobj->ID );
}
}
$recursing = false;
return $url;
}
/* content link filter */
add_filter( 'the_content', 'change_amp_url_content' );
function change_amp_url_content($content)
{
$dom = new DOMDocument();
$dom->loadHTML($content);
$tags = $dom->getElementsByTagName('a');
foreach ($tags as $tag) {
$link = $tag->getAttribute('href'); // original url
$extralink = '';
if(stristr($link,'#')) {
$pagelinktemp = explode("#",$link);
$pagelink = $pagelinktemp[0];
$extralink = '#'.$pagelinktemp[1];
} else {
$pagelink = $link;
}
if($pagelink!="") {
$postid = url_to_postid($pagelink);
$postobj = get_post($postid); // getting appropriate post object
if($postobj) {
$newlink = change_amp_url( $pagelink, $postobj ); //new url
}
else {
$newlink = $link;
}
}
else {
$newlink = $link;
}
if($link != $newlink) // change if only links are different
{
$content = str_replace($link, $newlink.$extralink, $content);
}
}
return $content;
}
/* override canonical link */
add_filter( 'wpseo_canonical', 'amp_override_canonical' );
function amp_override_canonical($url) {
if ( substr($url,-4)=="/amp" ) {
$url = substr($url,0,-4);
}
return $url;
}
Первая функция предоставит URL AMP, если он существует.
Второй будет циклически проходить по каждому URL в контенте и при необходимости изменяться на AMP URL.
Последний перезапишет канонический URL, отображаемый через плагин Yoast SEO.
Если вы хотите заменить жестко закодированные ссылки внутри вашего поста, я бы предложил вам использовать фильтр «the_content» для wordpress.
https://codex.wordpress.org/Plugin_API/Filter_Reference/the_content
add_filter( 'the_content', 'filter_function_name' )
Из этого вы должны иметь возможность регулярного выражения сопоставить ссылку и добавить / amp к ней.
Пример псевдокода:
function my_the_content_filter($content)
{
if (function_exists('is_amp_endpoint') && is_amp_endpoint()) {
$patterns = array(
//patterns
);
$replacements = array(
//replacements
);
$content = preg_replace($patterns, $replacements, $content);
}
return $content;
}
add_filter('the_content', 'my_the_content_filter');
Я протестировал код, предоставленный Outsource WordPress, и в целом он работает нормально, но функция ‘amp_override_canonical перезаписывает все URL страницы, удаляя / amp.
Я внес некоторые изменения в этот кусок кода, но они не работают, как я ожидаю. Кажется, что функция wpseo_canonical вызывается в другом контексте.
add_filter( 'wpseo_canonical', 'amp_override_canonical' );
function amp_override_canonical($url) {
if ( substr($url,-4)=="/amp" ) {
$url = substr($url,0,-4);
}
return $url;
}