在WordPress中,尽管你把固定链接设置成 /%postname%.html 这种形式,也只能给文章的URL添加 .html 后缀,其余页面的URL都是没有 .html 后缀的。这次我们讲讲如何给WordPress博客的页面URL添加.html后缀。

使用插件

如果想给页面URL添加 .html 后缀,可以使用使用这款插件:.html on PAGES

如果想给页面URL添加 .php 后缀,可以使用使用这款插件:.php on PAGES

特定页面不添加后缀

 .html on PAGES 插件会给所有页面都添加上.html后缀,但是问题又来了,如果我们不想给 sitemap 页面URL添加 .html 后缀,保持 /sitemap,而不是 /sitemap.html,那么怎么办呢?如果你有这个需求,可以用文本编辑器打开插件目录下的html-on-pages.php,查找:

add_filter('user_trailingslashit', 'no_page_slash',66,2);

将其替换成:

add_filter('page_link', 'blog_permalinks_page_link', 10, 2);
function blog_permalinks_page_link($permalink, $page) {
  $pos = strpos($permalink, "/sitemap.html");
  if ($pos !== false) {
    $permalink = str_replace("/sitemap.html", "/sitemap", $permalink);
  }
  return $permalink;
}

add_filter('user_trailingslashit', 'no_page_slash', 66, 2);

接着查找:

function html_page_permalink() {

将其替换成:

function html_page_permalink() {
  $string = $_SERVER['REQUEST_URI'];
  $pos = strpos($string, "/sitemap.html");
  if ($pos !== false) {
    switch_to_blog(1); //We are using WPMU if you are not you won't need this line.
    wp_redirect(get_option('home') . str_replace('/sitemap.html', '/sitemap', $string), 301);
    exit();
  }
  else {
    $pos = strpos($string, "/sitemap");
    if ($pos !== false) {
      $_SERVER['REQUEST_URI'] = str_replace("/sitemap", "/sitemap.html", $string);
      global $wp;
      $wp->parse_request();
    }
  }

好了,修改就到此结束。你可以根据把代码中的 sitemap 改成你的页面别名。


WordPressHTML

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。