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

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

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

<?php    
/*  
 Template Name: htmlSitemap  
*/    
?>    
<!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">    

## <?php bloginfo('name'); ?>'s SiteMap 

<center></center>    
<div id="nav">[/">**<?php bloginfo('name'); ?>**](<?php bloginfo() &raquo; [">站点地图](<?php echo get_permalink(); ?)</div>    
<div id="content">    

### 最新文章

<?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) :?>*   [" title="<?php the_title(); ?>" target="_blank"><?php the_title(); ?>](<?php the_permalink(); ?)    
</div>    
<div id="content">    
<li class="categories">分类目录

</li>    
</div>    
<div id="content">    
<li class="categories">单页面</li>    
<?php wp_page_menu( $args ); ?>    
</div>    
<div id="footer">查看博客首页: **[/"><?php bloginfo('name'); ?>](<?php bloginfo()**</div>

<center>    
<div style="text-algin: center; font-size: 11px">**[/" target="_blank">Baidu-SiteMap](<?php bloginfo()** 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; ?>

</div>    

</center>    
</body>    
</html>  

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

    • *

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、需要添加转发规则

nginx下的规则:

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

.htaccess下的规则

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

参考文章:
WordPress无插件实现html和xml两种格式站点地图
http://www.macrr.com/no-plugin-sitemap.html


 继续浏览关于 技术WordPress 的文章

 本文最后更新于 2019/07/21 03:08:37,可能因经年累月而与现状有所差异

 引用转载请注明:icret > 教程 > WordPress无插件实现html和xml两种格式站点地图