WordPress无插件实现html和xml两种格式站点地图

很多网站都有生成站点地图,包括xml格式和html格式的,这样会利于搜索引擎蜘蛛对网站信息的结构化收录。在这方面很多都是用插件来实现的,比如柳城的,当然我们都知道能少用一个插件就尽量不用。所以使用代码来实现html和xml两种格式站点地图就非常好了,代码在timle看到的,这里给大家说下相关方法。

HTML版站点地图方法:

1、创建一个一个php文档,将以下代码复制进去,命名为sitemap.php,上传到主题文件夹里。

  1. <?php  
  2. /* 
  3.  Template Name: Sitemap 
  4. */  
  5. ?>  
  6. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
  7. <html xmlns="http://www.w3.org/1999/xhtml">  
  8. <head profile="http://gmpg.org/xfn/11">  
  9. <meta http-equiv="Content-Type" content="text/html; charset=<?php bloginfo( 'charset' ); ?>" />  
  10. <title>站点地图 - <?php bloginfo('name'); ?></title>  
  11. <meta name="keywords" content="站点地图,<?php bloginfo('name'); ?>" />  
  12. <meta name="copyright" content="<?php bloginfo('name'); ?>" />  
  13. <link rel="canonical" href="<?php echo get_permalink(); ?>" />  
  14. <style type="text/css">  
  15.     body {font-family: Microsoft Yahei,Verdana;font-size:13px;margin:0 auto;color: #000000;background: #ffffff;width: 990px;margin: 0 auto}  
  16.     a:link,a:visited {color:#000;text-decoration:none;}  
  17.     a:hover {color:#08d;text-decoration:none;}  
  18.     h1,h2,h3,h4,h5,h6 {font-weight:normal;}  
  19.     img {border:0;}  
  20.     li {margin-top: 8px;}  
  21.     .page {padding: 4px; border-top: 1px #EEEEEE solid}  
  22.     .author {background-color:#EEEEFF; padding: 6px; border-top: 1px #ddddee solid}  
  23.     #nav, #content, #footer {padding: 8px; border: 1px solid #EEEEEE; clear: both; width: 95%; margin: auto; margin-top: 10px;}  
  24. </style>  
  25. </head>  
  26. <body vlink="#333333" link="#333333">  
  27. <h2 style="text-align: center; margin-top: 20px"><?php bloginfo('name'); ?>'s SiteMap </h2>  
  28. <center></center>  
  29. <div id="nav"><a href="<?php bloginfo('url'); ?>/"><strong><?php bloginfo('name'); ?></strong></a> &raquo; <a href="<?php echo get_permalink(); ?>">站点地图</a></div>  
  30. <div id="content">  
  31. <h3>最新文章</h3>  
  32. <ul>  
  33. <?php  
  34. $previous_year = $year = 0;  
  35. $previous_month = $month = 0;  
  36. $ul_open = false;  
  37.   
  38. $myposts = get_posts('numberposts=-1&orderby=post_date&order=DESC');  
  39.   
  40. foreach($myposts as $post) :  
  41. ?>  
  42. <li><a href="<?php the_permalink(); ?>" title="<?php the_title(); ?>" target="_blank"><?php the_title(); ?></a></li>  
  43. <?php endforeach; ?>  
  44. </ul>  
  45. </div>  
  46. <div id="content">  
  47. <li class="categories">分类目录<ul>  
  48. <?php wp_list_categories('title_li='); ?>  
  49. </ul></li>  
  50. </div>  
  51. <div id="content">  
  52. <li class="categories">单页面</li>  
  53. <?php wp_page_menu( $args ); ?>  
  54. </div>  
  55. <div id="footer">查看博客首页: <strong><a href="<?php bloginfo('url'); ?>/"><?php bloginfo('name'); ?></a></strong></div><br />  
  56. <center>  
  57. <div style="text-algin: center; font-size: 11px"><strong><a href="http://www.macrr.com/" target="_blank">Baidu-SiteMap</a></strong> 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>  
  58.   
  59.   
  60. </center>  
  61. </body>  
  62. </html>  

2、后台新建页面,模版选择站点地图即可(如下图所示)。
WordPress无插件实现html和xml两种格式站点地图

XML版站点地图方法:

1、创建一个一个php文档,将以下代码复制进去,命名为xmlmap.php,上传到网站根目录里。

  1. <?php   
  2. require('./wp-blog-header.php');   
  3. header("Content-type: text/xml");   
  4. header('HTTP/1.1 200 OK');   
  5. $posts_to_show = 1000; // 获取文章数量   
  6. echo '<?xml version="1.0" encoding="UTF-8"?>';   
  7. echo '<urlset xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"   
  8. xsi:schemaLocation="http://www.sitemaps.org/schemas/sitemap/0.9 http://www.sitemaps.org/schemas/sitemap/0.9/sitemap.xsd">';   
  9. ?>   
  10. <!-- generated-on=<?php echo get_lastpostdate('blog'); ?>-->   
  11. <?php   
  12. header("Content-type: text/xml");   
  13. $myposts = get_posts( "numberposts=" . $posts_to_show );   
  14. foreach$myposts as $post ) { ?>   
  15.  <url>   
  16.  <loc><?php the_permalink(); ?></loc>   
  17.  <lastmod><?php the_time('c') ?></lastmod>   
  18.  <changefreq>monthly</changefreq>   
  19.  <priority>0.6</priority>   
  20.  </url>   
  21. <?php } // end foreach ?>   
  22. </urlset>  

2、需要添加转发规则

  1. RewriteEngine On  
  2. RewriteBase /  
  3. RewriteRule ^sitemap.xml$ sitemap.php  

添加到.htaccess文件
  nginx下的规则:

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

发表评论

:?::razz::sad::evil::!::smile::oops::grin::eek::shock::???::cool::lol::mad::twisted::roll::wink::idea::arrow::neutral::cry::mrgreen:

目前评论:4   其中:访客  3   博主  1

    • 今非昔比 今非昔比 1 来自天朝的朋友 QQ浏览器 Windows 10 广东省东莞市 电信

      HTML版已经用上啦!感谢分享!

      • 狂放 狂放 2 未知系统 谷歌浏览器 Windows 10 运营商级NAT(宽带运营商局域网)

        这样的东西要是被C就阔怕了

        • 123 123 1 这家伙可能用了美佬的代理 火狐浏览器 Windows 10 美国 圣安娜Krypt机房

          .html文件竟然出现了乱码

            • 闲鱼 闲鱼 【博主】 来自天朝的朋友 QQ浏览器 iPhone iPhone OS 9_1 like Mac OS X) AppleWebKit 湖南省长沙市 电信

              @123 编码问题,不要用记事本