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

建站教程 阅读

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

HTML版站点地图方法:

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

<?php   /*   Template Name: Sitemap  */   ?> 
  <!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>&raquo;
        <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=f alse;   $myposts=g et_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">
          <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> </center> </body></html> 

2、后台新建页面,模版选择站点地图即可

XML版站点地图方法:

1、创建一个一个php文档,将以下代码复制进去,命名为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'); ?>-->  
<?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、需要添加转发规则

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

添加到.htaccess文件

nginx下的规则:

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

本文链接:https://niujc.com/com/1360889.html

栏目:建站教程
来源:
标签:wordpress
时间:2022-06-23

晚上好!当前时间为
目前距离2023年春节还有
TOP