wordpress极致优化 免插件实现两种格式的网站地图功能

自然 2017年12月17日15:10:18 发表评论 88
摘要

网站地图一般所有网站都有的,之前一直都是用百度地图插件,自动生成网站地图,包括xml格式和html格式,但是如果插件能少一个而其功能还不少,那也是极好的。除去多余的插件可以极大的优化wordpress性能,提升用户体验

wordpress极致优化 免插件实现两种格式的网站地图功能

前言

网站地图一般所有网站都有的,之前一直都是用百度地图插件,自动生成网站地图,包括xml格式和html格式,但是如果插件能少一个而其功能还不少,那也是极好的。把云落老哥的文章倒了过来,经典应该被更多人知道。

生成HTML地图

下载文章底部代码另存为sitemap.php,放到主题的页面模板那里,一般和你的友情链接模板在一起,然后在WordPress后台新建页面,选择网站地图模板。

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

 

  1. //页面伪静态
  2. add_action('init', 'html_page_permalink', -1);
  3. register_activation_hook(__FILE__, 'active');
  4. register_deactivation_hook(__FILE__, 'deactive');
  5. function html_page_permalink() {
  6.     global $wp_rewrite;
  7.  if ( !strpos($wp_rewrite->get_page_permastruct(), '.html')){
  8.         $wp_rewrite->page_structure = $wp_rewrite->page_structure . '.html';
  9.  }
  10. }
  11. add_filter('user_trailingslashit', 'no_page_slash',66,2);
  12. function no_page_slash($string$type){
  13.    global $wp_rewrite;
  14.     if ($wp_rewrite->using_permalinks() && $wp_rewrite->use_trailing_slashes==true && $type == 'page'){
  15.         return untrailingslashit($string);
  16.   }else{
  17.    return $string;
  18.   }
  19. }
  20. function active() {
  21.     global $wp_rewrite;
  22.     if ( !strpos($wp_rewrite->get_page_permastruct(), '.html')){
  23.         $wp_rewrite->page_structure = $wp_rewrite->page_structure . '.html';
  24.  }
  25.   $wp_rewrite->flush_rules();
  26. }
  27.     function deactive() {
  28.         global $wp_rewrite;
  29.         $wp_rewrite->page_structure = str_replace(".html","",$wp_rewrite->page_structure);
  30.         $wp_rewrite->flush_rules();
  31. }

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

XML网站地图

 

  1. <?php
  2. require('./wp-blog-header.php');
  3. header("Content-type: text/xml");
  4. header('HTTP/1.1 200 OK');
  5. $posts_to_show = 1000; // 获取文章数量
  6. echo '<?xml version="1.0" encoding="UTF-8"?>';
  7. echo '<urlset xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"
  8. xsi:schemaLocation="http://www.sitemaps.org/schemas/sitemap/0.9 http://www.sitemaps.org/schemas/sitemap/0.9/sitemap.xsd">';
  9. ?>
  10. <!-- generated-on=<?php echo get_lastpostdate('blog'); ?>-->
  11.   <url>
  12.       <loc><?php echo site_url(); ?></loc>
  13.       <lastmod><?php echo get_lastpostdate('blog'); ?></lastmod>
  14.       <changefreq>daily</changefreq>
  15.       <priority>1.0</priority>
  16.   </url>
  17. <?php
  18. header("Content-type: text/xml");
  19. $myposts = get_posts( "numberposts=" . $posts_to_show );
  20. foreach$myposts as $post ) { ?>
  21.   <url>
  22.       <loc><?php the_permalink(); ?></loc>
  23.       <lastmod><?php the_time('c') ?></lastmod>
  24.       <changefreq>monthly</changefreq>
  25.       <priority>0.6</priority>
  26.   </url>
  27. <?php } // end foreach ?>
  28. </urlset>

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

  1. RewriteEngine On
  2. RewriteBase /
  3. RewriteRule ^sitemap.xml$ sitemap.php

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

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

代码下载

 

  1. <?php
  2. /*
  3.  Template Name: 站点地图
  4. */
  5. ?>
  6. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  7. <html xmlns="http://www.w3.org/1999/xhtml">
  8. <head profile="http://gmpg.org/xfn/11">
  9. <meta http-equiv="Content-Type" content="text/html; charset=<?php bloginfo( 'charset' ); ?>" />
  10. <title>站点地图 - <?php bloginfo('name'); ?></title>
  11. <meta name="keywords" content="站点地图,<?php bloginfo('name'); ?>" />
  12. <meta name="copyright" content="<?php bloginfo('name'); ?>" />
  13. <link rel="canonical" href="<?php echo get_permalink(); ?>" />
  14. <style type="text/css">
  15.     body {font-family: Microsoft Yahei,Verdana;font-size:13px;margin:0 auto;color: #000000;background: #ffffff;width: 990px;margin: 0 auto}
  16.     a:link,a:visited {color:#000;text-decoration:none;}
  17.     a:hover {color:#08d;text-decoration:none;}
  18.     h1,h2,h3,h4,h5,h6 {font-weight:normal;}
  19.     img {border:0;}
  20.     li {margin-top: 8px;}
  21.     .page {padding: 4px; border-top: 1px #EEEEEE solid}
  22.     .author {background-color:#EEEEFF; padding: 6px; border-top: 1px #ddddee solid}
  23.     #nav, #content, #footer {padding: 8px; border: 1px solid #EEEEEE; clear: both; width: 95%; margin: auto; margin-top: 10px;}
  24. </style>
  25. </head>
  26. <body vlink="#333333" link="#333333">
  27. <h2 style="text-align: center; margin-top: 20px"><?php bloginfo('name'); ?>'s SiteMap </h2>
  28. <center></center>
  29. <div id="nav"><a href="<?php bloginfo('url'); ?>/"><strong><?php bloginfo('name'); ?></strong></a> » <a href="<?php echo get_permalink(); ?>">站点地图</a></div>
  30. <div id="content">
  31. <h3>最新文章</h3>
  32. <ul>
  33. <?php
  34. $previous_year = $year = 0;
  35. $previous_month = $month = 0;
  36. $ul_open = false;
  37. $myposts = get_posts('numberposts=-1&orderby=post_date&order=DESC');
  38. foreach($myposts as $post) :
  39. ?>
  40. <li><a href="<?php the_permalink(); ?>" title="<?php the_title(); ?>" target="_blank"><?php the_title(); ?></a></li>
  41. <?php endforeach; ?>
  42. </ul>
  43. </div>
  44. <div id="content">
  45. <li class="categories">分类目录<ul>
  46. <?php wp_list_categories('title_li='); ?>
  47. </ul></li>
  48. </div>
  49. <div id="content">
  50. <li class="categories">单页面</li>
  51. <?php wp_page_menu( $args ); ?>
  52. </div>
  53. <div id="footer">查看博客首页: <strong><a href="<?php bloginfo('url'); ?>/"><?php bloginfo('name'); ?></a></strong></div><br />
  54. <center>
  55. <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; ?><br /><br /></div>
  56. </center>
  57. </body>
  58. </html>

效果预览

见本站底部说明

weinxin
公众号:网科文媒
快来关注一下,你想要的这里都有喔!! -运维笔记 -建站知识 -绿色软件 -爱听音乐 -热门电影 -校园语录 -视频教程 -OFFICES -购物联盟 -智慧服务 -运维托管 -建站指导
自然

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: