WordPress不使用插件创建xml和html网站地图

网站地图,又称站点地图,它就是一个页面,上面放置了网站上需要搜索引擎抓取的页面链接(注:不是所有页面)。大多数…

网站地图,又称站点地图,它就是一个页面,上面放置了网站上需要搜索引擎抓取的页面链接(注:不是所有页面)。大多数人在网站上找不到自己所需要的信息时,可能会将网站地图作为一种补救措施。搜索引擎蜘蛛非常喜欢网站地图。
IMG_0
下面我们来看下,WordPress网站中不用插件如何制作网站地图:

创建xml网站地图

xml地图主要是方便搜索引擎机器人抓取网站链接,xml地图的创建方法比较简单,新建一个名为xmlmap.php的文件,然后填入以下代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65

<?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=”http://www.sitemaps.org/schemas/sitemap/0.9″ xmlns:mobile=”http://www.baidu.com/schemas/sitemap-mobile/1/”>’
?>
<url>
<loc><?php echo get_home_url(); ?></loc>
<lastmod><?php $ltime = get_lastpostmodified(GMT);$ltime = gmdate(‘Y-m-d’, strtotime($ltime)); echo $ltime; ?></lastmod>
<changefreq>daily</changefreq>
<priority>1.0</priority>
</url>
<?php
/* 文章页面 */
$myposts = get_posts( “numberposts=” . $posts_to_show );
foreach( $myposts as $post ) { ?>
<url>
<loc><?php the_permalink(); ?></loc>
<lastmod><?php the_time(‘Y-m-d’) ?></lastmod>
<changefreq>daily</changefreq>
<priority>0.6</priority>
</url>
<?php } /* 文章循环结束 */ ?>
<?php
/* 单页面 */
$mypages = get_pages();
if(count($mypages) > 0) {
foreach($mypages as $page) { ?>
<url>
<loc><?php echo get_page_link($page->ID); ?></loc>
<lastmod><?php echo str_replace(” “,“T”,get_page($page->ID)->post_modified); ?>+00:00</lastmod>
<changefreq>weekly</changefreq>
<priority>0.6</priority>
</url>
<?php }} /* 单页面循环结束 */ ?>
<?php
/* 博客分类 */
$terms = get_terms(‘category’, ‘orderby=name&hide_empty=0’ );
$count = count($terms);
if($count > 0){
foreach ($terms as $term) { ?>
<url>
<loc><?php echo str_replace(“./”,“”,get_term_link($term, $term->slug)); ?></loc>
<changefreq>weekly</changefreq>
<priority>0.8</priority>
</url>
<?php }} /* 分类循环结束 */?>
<?php
/* 标签(可选) */
$tags = get_terms(“post_tag”);
foreach ( $tags as $key => $tag ) {
$link = get_term_link( intval($tag->term_id), “post_tag” );
if ( is_wp_error( $link ) )
return false;
$tags[ $key ]->link = $link;
?>
<url>
<loc><?php echo $link ?></loc>
<changefreq>monthly</changefreq>
<priority>0.4</priority>
</url>
<?php } /* 标签循环结束 */ ?>
</urlset>

将xmlmap.php文件传至网站根目录,然后根据环境写好url转发规则。

首先是apache下的规则:

1
2
3

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

将以上代码加入到.htaccess文件即可,接下来是nginx下规则:

1

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

效果如:xml网站地图

创建html网站地图

html站点地图是为了方便读者快速了解网站内容,首先在主题目录下创建WordPress站点地图模板文件htmlmap.php,将下面代码复制进文件中:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98

<?php
require(‘./wp-blog-header.php’);
header(“Content-type: text/html”);
header(‘HTTP/1.1 200 OK’);
$posts_to_show = 1000;
?>
<?php /** @package WordPress 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>
<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: Verdana;
FONT-SIZE: 12px;
MARGIN: 0;
color: #000000;
background: #ffffff;
}
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’); ?>站点地图</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>
<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; ?>
</div>
</center>
<center>
© <?php echo date(‘Y’); ?> <a href=”<?php bloginfo(‘url’); ?>/”
style=”cursor:help”><?php bloginfo(‘name’); ?></a> 版权所有.
</div>
</center>
</body>
</html>

接着如同上例xml站点地图做url重写。

效果如:html网站地图

类别:WordPress 进阶教程

本文收集自互联网,转载请注明来源。
如有侵权,请联系 wper_net@163.com 删除。

评论 (0)COMMENT

登录 账号发表你的看法,还没有账号?立即免费 注册