WordPress 免插件生成网站地图 sitemap.xml
几年前,刚玩WordPress搭建博客时,使用的插件生成网站地图,详见之前的米扑博客:
安装插件
Google XML Sitemaps 官网:https://wordpress.org/plugins/google-sitemap-generator/
Baidu Sitemap Generator 官网:https://wordpress.org/plugins/baidu-sitemap-generator/
Google XML Sitemaps 插件:google-sitemap-generator.4.0.9.zip
Baidu Sitemap Generator 插件:baidu-sitemap-generator.zip
或在安装插件(wp-admin/plugin-install.php)页面搜索“Google XML Sitemaps” 和 “Baidu Sitemap Generator”
本文介绍的是免插件生成网站地图 sitemap.xml
1. 添加代码到网站根目录
vim sitemap-blog.php
<?php
require('./wp-blog-header.php');
header("Content-type: text/xml");
header('HTTP/1.1 200 OK');
$posts_to_show = 100;
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/">'
?>
<!-- generated-on=<?php echo get_lastpostdate('blog'); ?> DIY By 米扑博客(https://blog.mimvp.com)-->
<url>
<loc><?php echo get_home_url(); ?></loc>
<lastmod><?php $ltime = get_lastpostmodified(GMT);$ltime = gmdate('Y-m-d\TH:i:s+00:00', strtotime($ltime)); echo $ltime; ?></lastmod>
<changefreq>daily</changefreq>
<priority>1.0</priority>
</url>
<?php
/* 文章页面 */
$myposts = get_posts( "category=-4766&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.9</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.8</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 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>
说明:
1) get_posts( "category=-4766&numberposts=" . $posts_to_show ) 获取发表的文章函数,$posts_to_show 为文章数
2) category=-4766 表示排除分类号为 4766 的所有文章(米扑代理)
2. Web服务器转发(不推荐)
1) Nginx
rewrite ^/sitemap-blog.xml$ /sitemap-blog.php last;
2) Apache
RewriteRule ^(sitemap-blog)\.xml$ $1.php
3. 定时生成 sitemap-blog.xml (推荐)
1)http 或 授权ssl证书的 https
05 3 * * * curl https://blog.mimvp.com/sitemap-mimvp.php -o /var/www/html/wordpress/sitemap-mimvp.xml > /dev/null 2>&1
2)非授权ssl证书的 https
05 3 * * * curl --insecure https://blog.mimvp.com/sitemap-mimvp.php -o /var/www/html/wordpress/sitemap-mimvp.xml > /dev/null 2>&1
扩展知识:
get_posts 简介
get_posts 函数是 get_post 的复数新形势,支持众多参数选择需要提取的文章,
如果你对 WordPress 有更深了解的话,你也有可能是用 WP_Query 来替代该函数。
该函数属于 WordPress 的内置函数,用于在 WordPress 中提取多篇指定或随机文章。
<?php
$args = array(
'numberposts' => 5,
'offset' => 0,
'category' => ,
'orderby' => 'post_date',
'order' => 'DESC',
'include' => ,
'exclude' => ,
'meta_key' => ,
'meta_value' => ,
'post_type' => 'post',
'post_mime_type' => ,
'post_parent' => ,
'post_status' => 'publish' );
$posts_array = get_posts( $args );
?>
用法说明:
$args是该函数必要的变量
get_posts( $args )将返回数组型的变量
参数说明:
<?php
$args = array(
//需要提取的文章数
'numberposts' => 10,
//以第几篇文章为起始位置
'offset' => 0,
//分类的ID,多个用逗号将分类编号隔开,或传递编号数组,可指定多个分类编号。
//大部分 CMS 使用该函数的重点。
'category' => ,
//排序规则(注1)
'orderby' => 'post_date',
//升序、降序 'ASC' —— 升序 (低到高) 'DESC' —— 降序 (高到底)
'order' => 'DESC',
//要显示文章的ID
'include' => ,
//要排除文章的ID
'exclude' => ,
//自定义字段名称
'meta_key' => ,
//自定义字段的值,配合上一个参数,来选择显示符合自定义字段数值的文章。
'meta_value' => ,
//post(日志)——默认,page(页面),
//attachment(附件),any —— (所有)
'post_type' => 'post',
//文章的 mime 类型
'post_mime_type' => ,
//要显示文章的父级 ID
'post_parent' => ,
//文章状态
'post_status' => 'publish' );
?>
说明:
‘author’ —— 按作者数值编号排序
‘category’ —— 按类别数值编号排序
‘content’ —— 按内容排序
‘date’ —— 按创建日期排序
‘ID’ —— 按文章编号排序
‘menu_order’ —— 按菜单顺序排序。仅页面可用。
‘mime_type’ —— 按MIME类型排序。仅附件可用。
‘modified’ —— 按最后修改时间排序。
‘name’ —— 按存根排序。
‘parent’ —— 按父级ID排序
‘password’ —— 按密码排序
‘rand’ —— 任意排序结果
‘status’ —— 按状态排序
‘title’ —— 按标题排序
‘type’ —— 按类型排序
用法示例
随机在 WordPress 中获取3篇文章
<?php
$posts_rand = get_posts('numberposts=10&orderby=rand');
?>
query_posts() 和 get_posts() 函数,接受大部分的参数,使用同样结构的数据库查询语句,并能达到一样的目的,但部分主题作者提示 query_posts()有可能会扰乱 WordPress 主循环,所以在这里不推荐使用。
get_posts() 使用不难,难在获取文章后怎样在页面中显示,这里就需要有一定的 PHP 知识了。
如果是在文章循环之外想要将查询内容显示出来,可以看一下setup_postdata这个函数,这个函数会给那些用惯了模板标签的童鞋很大的帮助。
版权所有: 本文系米扑博客原创、转载、摘录,或修订后发表,最后更新于 2018-04-22 06:16:20
侵权处理: 本个人博客,不盈利,若侵犯了您的作品权,请联系博主删除,莫恶意,索钱财,感谢!
之前使用过代码生成站点地图,但是一点击固定连接 站点地图就会消失;
并且百度站长统计的是蜘蛛抓取不到,所以就用的插件,也正是贵站正在使用的这款 站点地图插件。
哈哈 握个手