问题
当文章有分页的时候,wordpress生成的永久链接是page.html/2的形式,前面一段是文章的$link,后面的数字代表分页$number。那么问题来了,挖掘……不对,从逻辑上讲这到底是个html文件还是一个目录呢?
难看
在.html这个静态文件后面加上一个/和数字简直令人摸不着头脑,这还只是其次,重要的是,我发现搜索引擎根本不收录这样奇怪的链接,这个真是无法接受,我写的东西首尾都很重要,不能因为分个页就被忽视了。
不收录
解决方案
思路
利用filter wp_link_pages_link 将分页链接/123456重写为page-[123456].html。
利用wordpress或者服务器的RewriteRule将page-[123456].html还原为/123456
添加钩子redirect_canonical,防止wordpress从page-[123456].html到/123456的强行跳转。
function __construct()
{
$this->separator = '/page-';
// (.+?)/([^/]+).html(/[0-9]+)?/?
$this->post_rule = '(.+?)/([^/]+)(' . $this->separator . '([0-9]+))+.html/?$';
if (!is_admin() || defined('DOING_AJAX')) :
add_filter('wp_link_pages_link',array($this,'inner_page_link_format'),10,2); // for inner pages
add_filter('redirect_canonical','cancel_redirect_for_paged_posts'),2);
endif;
if (is_admin()) :
add_filter('rewrite_rules_array','pagelink_rewrite_rules'));
endif;
}
{
$this->separator = '/page-';
// (.+?)/([^/]+).html(/[0-9]+)?/?
$this->post_rule = '(.+?)/([^/]+)(' . $this->separator . '([0-9]+))+.html/?$';
if (!is_admin() || defined('DOING_AJAX')) :
add_filter('wp_link_pages_link',array($this,'inner_page_link_format'),10,2); // for inner pages
add_filter('redirect_canonical','cancel_redirect_for_paged_posts'),2);
endif;
if (is_admin()) :
add_filter('rewrite_rules_array','pagelink_rewrite_rules'));
endif;
}
/**
- 修改post分页链接的格式
- @param string $link
- @param int $number
- @return string
/
function inner_page_link_format($link,$number)
{
if ($number > 1)
{
if (preg_match('%<a href="..html/\d"%',$link))
{
$link = preg_replace("%(.html)/(\d)%",$this->separator . "$2$1",$link);
}
}
return $link;
}
/**
- 为新的链接格式增加重定向规则,移除原始分页链接的重定向规则,防止重复收录
- 访问原始链接将返回404
- @param array $rules
- @return array
*/
function pagelink_rewrite_rules($rules)
{
$new_rule[$this->post_rule] = 'index.php?name=$matches[2]&page=$matches[4]';
return $new_rule + $rules;
}
/**
- 禁止WordPress将页面分页链接跳转到原来的格式
- @param string $redirect_url
- @param string $requested_url
- @return bool
*/
function cancel_redirect_for_paged_posts($redirect_url,$requested_url)
{
global $wp_query;
if (is_single() && $wp_query->get('page') > 1)
{
return false;
}
return true;
}
}
new Rewrite_Inner_Page_Links();