• 明天我们家宝宝满月了
  • 一晚上忙了好几个小时,终于把支付前台通知解决了
  • 原计划要增加另外一种支付方案,现在可能要被搁置了
  • 今天上午刚刚注册了华为云,然后刚刚华为云的客服小姐姐就来电话了,小姐姐声音挺好听的
  • 今天无意中注册了华为云,然后发现跟阿里云基本一个模样,甚至连价格都一样
  • 继续测试一下
  • 发现一个问题就是,微信语音发送说说的时候,不要拦截没有UA的数据请求
  • 测试一下连接
  • 终于下雪了
  • 有赞的支付暂时用不了了,所以重新开发另一个支付插件

免插件实现两种格式的网站地图功能

WordPress 云落 4年前 (2015-03-18) 593次浏览 已收录 9个评论
文章目录[隐藏]

无插件,纯代码实现网站地图功能,希望云落推荐的这个你能喜欢

sitemap

前言

网站地图一般所有网站都有的,之前一直都是用百度地图插件,自动生成网站地图,包括xml格式和html格式,但是如果插件能少一个而其功能还不少,那也是极好的。折翅云落把来自奶嘴的旧的教程拿来重新写下,给出一个稍微修改的网站地图方案

生成HTML地图

下载文章底部的文件,放到主题的页面模板那里,一般和你的友情链接模板在一起,然后在WordPress后台新建页面,选择网站地图模板,具体可以先看看上面的原版教程。

下面开始不太一样了

新建页面时候,别名命名为sitemap,然后正常来说链接就是http://网站域名/sitemap
但是这个和正常的HTML地图链接不太一样,我们想要的是http://网站域名/sitemap.html 是把,其实就是页面伪静态的问题吧
在主题functions.php文件添加以下代码

//页面伪静态
add_action('init', 'html_page_permalink', -1);
register_activation_hook(__FILE__, 'active');
register_deactivation_hook(__FILE__, 'deactive');

function html_page_permalink() {
	global $wp_rewrite;
 if ( !strpos($wp_rewrite->get_page_permastruct(), '.html')){
		$wp_rewrite->page_structure = $wp_rewrite->page_structure . '.html';
 }
}
add_filter('user_trailingslashit', 'no_page_slash',66,2);
function no_page_slash($string, $type){
   global $wp_rewrite;
	if ($wp_rewrite->using_permalinks() && $wp_rewrite->use_trailing_slashes==true && $type == 'page'){
		return untrailingslashit($string);
  }else{
   return $string;
  }
}

function active() {
	global $wp_rewrite;
	if ( !strpos($wp_rewrite->get_page_permastruct(), '.html')){
		$wp_rewrite->page_structure = $wp_rewrite->page_structure . '.html';
 }
  $wp_rewrite->flush_rules();
}
	function deactive() {
		global $wp_rewrite;
		$wp_rewrite->page_structure = str_replace(".html","",$wp_rewrite->page_structure);
		$wp_rewrite->flush_rules();
}

然后需要在设置——固定连接那里重新保存一下,不然会404的

XML网站地图

<?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'); ?>-->
  <url>
      <loc><?php echo site_url(); ?></loc>
      <lastmod><?php echo get_lastpostdate('blog'); ?></lastmod>
      <changefreq>daily</changefreq>
      <priority>1.0</priority>
  </url>
<?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>

XML地图比较简单,上面这段代码保存为sitemap.php,保存在WordPress网站根目录,一般和wp-config.php在同一个目录。
然后需要添加转发规则

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

将这句代码添加到.htaccess文件,云落就是这样滴!
nginx下的规则是这样滴:

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

效果预览

网站地图XML      网站地图HTML

相关链接

下载代码文件

版权声明

本文改编自:wordpress非插件实现创建html以及xml格式的站点地图(sitemap)


-- 完 --
weinxin
扫码订阅,第一时间获得更新
微信扫码二维码,订阅我们网站的动态,另外不定时发送WordPress小技巧,你可以随时退订,欢迎订阅哦~

乐趣公园 , 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:免插件实现两种格式的网站地图功能
喜欢 (4)
云落
关于作者:
无折腾,不生活,我是一个WordPress菜鸟,一个玩淘宝的卖家,欢迎你认识我,我是云落!
发表我的评论
取消评论
表情 贴图 加粗 删除线 居中 斜体 签到

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

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址
(9)个小伙伴在吐槽
  1. 这个不错,收藏了
    夜色2017-05-26 19:02 回复 Linux | Chrome 53.0.2785.49
  2. nginx环境下上,代码加到function文件,然后网站就500错误,怎么回事呢?
    小菜菜2017-03-07 10:35 回复 Windows 10 | Chrome 58.0.3000.4
  3. 签到成功!签到时间:2016-12-27 11:06:48,每日打卡,生活更精彩哦~
    凯恩2016-12-27 11:09 回复 Windows 7 | Chrome 45.0.2454.101
  4. 这个挺不错的
    qkwu2015-04-14 13:52 回复 Windows 8.1 | Chrome 44.0.2369.0
  5. 主题改的不错
    体操之乡2015-04-07 10:23 回复 Windows 7 | Chrome 31.0.1650.63