当前位置:首页>技术文档>如何在wordpress网站中添加自动生成网站地图页面

如何在wordpress网站中添加自动生成网站地图页面

如何在wordpress网站中添加自动生成网站地图页面
WordPress的网站地图用一般的生成工具,生成之后都不能用,生成网站地图的插件也有很多,大家可以自行百度,这里主要是讲利用代码生成。能用代码解决的问题,坚决不用插件!
网站地图一般有两种格式,XML格式和HTML格式,其目的是可以让搜索引擎快速的爬行,也有利于搜索数据的收录。

1. XML地图生成方法

1.1 添加生成地图的代码

先将以下代码将保存为sitemap.php,上传到网站wordpress根目录。
<?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="https://www.sitemaps.org/schemas/sitemap/0.9" xmlns:mobile="https://www.baidu.com/schemas/sitemap-mobile/1/">'
?>
  <url>
      <loc><?php echo get_home_url(); ?></loc>
      <mobile:mobile type="pc,mobile"/>
      <lastmod><?php $ltime = get_lastpostmodified(GMT);$ltime = gmdate('Y-m-dTH:i:s+00:00', 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>
      <mobile:mobile type="pc,mobile"/>
      <lastmod><?php the_time('c') ?></lastmod>
      <changefreq>monthly</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>
      <mobile:mobile type="pc,mobile"/>
      <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 get_term_link($term, $term->slug); ?></loc>
      <mobile:mobile type="pc,mobile"/>
      <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>
      <mobile:mobile type="pc,mobile"/>
      <changefreq>monthly</changefreq>
      <priority>0.4</priority>
  </url>
<?php  } /* 标签循环结束 */ ?> 
</urlset>

 

1.2 设置伪静态

nginx的添加如下伪静态规则:
rewrite ^/sitemap.xml$ /sitemap.php last;

1.3 重起网络服务器

sudo systemctl reload nginx

1.4 查看网站地图

访问域名地址加上sitemap.xml,如:

2. HTML地图生成的方法

2.1 创建生成地图的模板文件

首先在主题根目录下创建WordPress站点地图模板文件sitemap-html.php,添加如下代码:
<!--?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 profile="http://gmpg.org/xfn/11"> 
  <meta http-equiv="Content-Type" content="text/html; charset=&lt;?php bloginfo('charset'); ?&gt;" /> 
  <title>站点地图 - &lt;?php bloginfo('name'); ?&gt;</title> 
  <meta name="keywords" content="站点地图,&lt;?php bloginfo('name'); ?&gt;" /> 
  <meta name="copyright" content="&lt;?php bloginfo('name'); ?&gt;" /> 
  <link rel="canonical" href="&lt;?php echo get_permalink(); ?&gt;" /> 
  <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="&lt;?php bloginfo('url'); ?&gt;/"><strong>
     <!--?php bloginfo('name'); ?--></strong></a> &raquo; 
   <a href="&lt;?php echo get_permalink(); ?&gt;">站点地图</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="&lt;?php the_permalink(); ?&gt;" title="&lt;?php the_title(); ?&gt;" 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="&lt;?php bloginfo('url'); ?&gt;/">
     <!--?php bloginfo('name'); ?--></a></strong>
  </div> 
  <center> 
   <div style="text-algin: center; font-size: 11px">
     Latest Update: 
    <!--?php $last = $wpdb--->get_results(&quot;SELECT MAX(post_modified) AS MAX_m FROM $wpdb-&gt;posts WHERE (post_type = 'post' OR post_type = 'page') AND (post_status = 'publish' OR post_status = 'private')&quot;); $last = date('Y-m-d G:i:s', strtotime($last[0]-&gt;MAX_m)); echo $last; ?&gt; 
   </div> 
  </center> 
  <center>
    &copy; 
   <!--?php echo date('Y'); ?--> 
   <a href="&lt;?php bloginfo('url'); ?&gt;/" style="cursor:help">
    <!--?php bloginfo('name'); ?--></a> 版权所有.  
  </center>  
 </body>
</html>

 

2.2 添加网站地图的页面

在WordPress后台中新建一个页面,模板类型选择:站点地图,其他内容不用填写直接发布。

2.3 可以查看你发布网站地图

进入上面发布的网站地址链接,即可查看html格式网站地图。

给TA打赏
共{{data.count}}人
人已打赏
技术文档

如何搭建个人网站

2022-5-6 23:58:31

技术文档

什么是DDoS攻击

2022-5-7 0:00:59

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索