WordPress无插件轻松实现html和xml站点地图
     2016-9-14    +0°    1024  

网站地图可以直接通过插件实现,而且简单方便,但是wordpress大多都用了很多插件,我们能少用就尽量少用吧。这里介绍怎么让WordPress无插件轻松实现html和xml站点地图。

本站演示HTML版站点地图:

本站演示xml版站点地图:

1、HTML版站点地图制作方法

1、下载sitemap.php文件,通过ftp上传到主题文件夹里。

2、然后通过新建页面即可(如下图所示)。注意下图的固定链接样式,需要修改固定链接设置才可以:

WordPress无插件轻松实现html和xml站点地图

然后将页面的链接加入到自己的想要的地方;如果你了解html和Wordpress的主题构造,可以自己任何地方调用。个人推荐就加在页面footer里。

2、xml版站点地图制作方法

1、下载sitemap.php文件,通过ftp上传到当前wordpress主题文件夹的根目录,然后新建页面,选择站点地图模板即可!这样一个html的站点地图就OK了。

2、在空间wordpress的根目录下创建xmlmap.php文件,添加下面内容。

<?php
require('./wp-blog-header.php');
header("Content-type: text/xml");
header('HTTP/1.1 200 OK');
$posts_to_show = 1000; // 获取文章数量
echo '<?xml version="1.0" encoding="UTF-8"?>';
echo '<urlset xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"
xsi:schemaLocation="http://www.sitemaps.org/schemas/sitemap/0.9 http://www.sitemaps.org/schemas/sitemap/0.9/sitemap.xsd">';
?>
<!-- generated-on=<?php echo get_lastpostdate('blog'); ?>-->
  <url>
      <loc>http://www.btnose.com/</loc>
      <lastmod><?php echo get_lastpostdate('blog'); ?></lastmod>
      <changefreq>daily</changefreq>
      <priority>1.0</priority>
  </url>
<?php
header("Content-type: text/xml");
$myposts = get_posts( "numberposts=" . $posts_to_show );
foreach( $myposts as $post ) { ?>
  <url>
      <loc><?php the_permalink(); ?></loc>
      <lastmod><?php the_time('c') ?></lastmod>
      <changefreq>monthly</changefreq>
      <priority>0.6</priority>
  </url>
<?php } // end foreach ?>
</urlset>

 
2、在空间wordpress的根目录下创建sitemap.xml空白文件。

3、根据不同的服务器环境来设置url转发规则!

首先是apache下的规则:

RewriteEngine On
RewriteBase /
RewriteRule ^sitemap.xml$ xmlmap.php

将以上代码加入到.htaccess文件即可,接下来是nginx下规则:

rewrite ^/sitemap.xml$ /xmlmap.php

现在直接访问:http://www.btnose.com/sitemap.xml,成功了!

文件下载