点击登录
  • 欢迎访问江西SEO朱曙明博客,本站提供SEO网站优化教程,分享SEO基础知识,讲解优化经验,提供免费SEO教程。
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏江西SEO吧。

wordpress无插件实现两种站点地图

生活 江西SEO博客 来源:咸鱼博客 277次浏览 已收录 0个评论 扫描二维码

很多网站都有生成站点地图,包括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 = 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"><strong><a href="http://www.timle.cn/sitemap_baidu.xml" 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、后台新建页面,模版选择站点地图即可(如下图所示)。

wordpress无插件实现两种站点地图

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;

本站的两个地图

HTML地图:http://www.zhushuming.com/sitemap.html

XML地图:http://www.zhushuming.com/sitemap.xml


喜欢 (3)
[15949548564]
分享 (0)
江西SEO博客
关于作者:
江西SEO朱曙明为你分享SEO知识技巧,帮助SEO新手站长快速学习成长。也分享一些生活美文。
发表我的评论
取消评论
表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址