芝兰生幽谷
不以无人而不芳

免插件纯代码实现网站地图sitemap.xml及html(wordpress)

sitemap在SEO当中的地位是非常高的。猫鼬博客现在是做了一个xml版的给蜘蛛爬取,一个html版的给用户使用。

插件也可以生成网站地图,但是个人还是不太喜欢用插件,那么,如何纯代码去创建sitemap呢?话不多说,且看下文:

HTML版

首先,新建个文件,命名为sitemap.php,用代码编辑器打开,复制代码进去并保存,然后将其上传到当前wordpress主题文件夹的根目录,新建页面,选择站点地图模板就可以了!

代码如下:


<?php
/*
Template Name: 站点地图
*/
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head profile="http://gmpg.org/xfn/11">
<meta http-equiv="Content-Type" content="text/html; charset=<?php bloginfo( 'charset' ); ?>" />
<title>站点地图 - <?php bloginfo('name'); ?></title>
<meta name="keywords" content="站点地图,<?php bloginfo('name'); ?>" />
<meta name="copyright" content="<?php bloginfo('name'); ?>" />
<link rel="canonical" href="<?php echo get_permalink(); ?>" />
<style type="text/css">
body {font-family: Microsoft Yahei,Verdana;font-size:13px;margin:0 auto;color: #000000;background: #ffffff;width: 990px;margin: 0 auto}
a:link,a:visited {color:#000;text-decoration:none;}
a:hover {color:#08d;text-decoration:none;}
h1,h2,h3,h4,h5,h6 {font-weight:normal;}
img {border:0;}
li {margin-top: 8px;}
.page {padding: 4px; border-top: 1px #EEEEEE solid}
.author {background-color:#EEEEFF; padding: 6px; border-top: 1px #ddddee solid}
#nav, #content, #footer {padding: 8px; border: 1px solid #EEEEEE; clear: both; width: 95%; margin: auto; margin-top: 10px;}
</style>
</head>
<body vlink="#333333" link="#333333">
<h2 style="text-align: center; margin-top: 20px"><?php bloginfo('name'); ?>'s SiteMap </h2>
<center></center>
<div id="nav"><a href="<?php bloginfo('url'); ?>/"><strong><?php bloginfo('name'); ?></strong></a> » <a href="<?php echo get_permalink(); ?>">站点地图</a></div>
<div id="content">
<h3>最新文章</h3>
<ul>
<?php
$previous_year = $year = 0;
$previous_month = $month = 0;
$ul_open = false;

$myposts = get_posts('numberposts=-1&orderby=post_date&order=DESC');

foreach($myposts as $post) :
?>
<li><a href="<?php the_permalink(); ?>" title="<?php the_title(); ?>" target="_blank"><?php the_title(); ?></a></li>
<?php endforeach; ?>
</ul>
</div>
<div id="content">
<li class="categories">分类目录<ul>
<?php wp_list_categories('title_li='); ?>
</ul></li>
</div>
<div id="content">
<li class="categories">单页面</li>
<?php wp_page_menu( $args ); ?>
</div>
<div id="footer">查看博客首页: <strong><a href="<?php bloginfo('url'); ?>/"><?php bloginfo('name'); ?></a></strong></div><br />
<center>
<div style="text-algin: center; font-size: 11px">Latest Update: <?php $last = $wpdb->get_results("SELECT MAX(post_modified) AS MAX_m FROM $wpdb->posts WHERE (post_type = 'post' OR post_type = 'page') AND (post_status = 'publish' OR post_status = 'private')");$last = date('Y-m-d G:i:s', strtotime($last[0]->MAX_m));echo $last; ?><br /><br /></div>
</center>
</body>
</html>

 

XML版

新建个文件,命名为sitemap.php,用代码编辑器打开,复制代码进去并保存,然后将其上传到当前空间的根目录

代码如下:

    1. <?php

 

    1. require(‘./wp-blog-header.php’);

 

    1. header(“Content-type: text/xml”);

 

    1. header(‘HTTP/1.1 200 OK’);

 

    1. $posts_to_show = 1000// 获取文章数量

 

    1. echo ‘<?xml version=“1.0” encoding=“UTF-8”?>’;

 

    1. echo ‘<urlset xmlns:xsi=“http://www.w3.org/2001/XMLSchema-instance” xmlns=“http://www.sitemaps.org/schemas/sitemap/0.9”

 

    1. xsi:schemaLocation=“http://www.sitemaps.org/schemas/sitemap/0.9 http://www.sitemaps.org/schemas/sitemap/0.9/sitemap.xsd”>’;

 

    1. ?>

 

    1. <!– generated-on=<?php echo get_lastpostdate(‘blog’); ?>–>

 

    1.   <url>

 

    1.       <loc>http://改成你自己的/</loc>

 

    1.       <lastmod><?php echo get_lastpostdate(‘blog’); ?></lastmod>

 

    1.       <changefreq>daily</changefreq>

 

    1.       <priority>1.0</priority>

 

    1.   </url>

 

    1. <?php

 

    1. header(“Content-type: text/xml”);

 

    1. $myposts = get_posts( “numberposts=” . $posts_to_show );

 

    1. foreach( $myposts as $post ) { ?>

 

    1.   <url>

 

    1.       <loc><?php the_permalink(); ?></loc>

 

    1.       <lastmod><?php the_time(‘c’) ?></lastmod>

 

    1.       <changefreq>monthly</changefreq>

 

    1.       <priority>0.6</priority>

 

    1.   </url>

 

    1. <?php } // end foreach ?>

 

    1. </urlset>

 

 

上传到根目录后,还需要根据服务器环境设置url转发规则,分apache和nginx的:


apache:
    1. RewriteEngine On

 

    1. RewriteBase /

 

    1. RewriteRule ^sitemap.xml$ xmlmap.php

 

 

nginx:

    1. rewrite ^/sitemap.xml$ /xmlmap.php;

 

 

将与自己服务器环境匹配的代码加入到.htaccess文件并上传。
到此为止,就算是纯代码实现了网站地图。
不过,猫鼬博客提醒大家,不要点固定连接,只要点击了固定链接.htaccess文件就会恢复为默认,我们在里面写的url转发也就没了。
如果不小心点击到了,就需要重新将url转发规则加到.htaccess文件里,再上传至根目录。
这个方法是之前看到的,出处已无法确认,个人觉得不错,分享给大家。

赞(0)
转载请注明出处:猫鼬博客 » 免插件纯代码实现网站地图sitemap.xml及html(wordpress)
分享到: 更多 (0)

评论 5

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址
  1. #1

    代码高亮出错,修复好了我再重发。 ❗

    十八5个月前 (05-13)回复
  2. #2

    好短的代码就能实现了,厉害,看起来比插件好 😐

    梁兴健5个月前 (05-14)回复
    • 大佬 ,你误会了,我代码高亮又叒叕出问题了,有两段很长的代码还没放出来。

      十八5个月前 (05-14)回复
  3. #3

    这个很好,之前用插件,总找不到很合适的

    X隐者博客5个月前 (06-02)回复
    • 需要的话可以联系我发代码,博客代码高亮挂了,最近很忙,有时间了换主题。

      十八5个月前 (06-02)回复