为WordPress 网站创建一个纯文本网站地图(Sitemap)

它的主要作用是为您的 WordPress 网站创建一个简单的、供搜索引擎使用的 URL 列表。搜索引擎(如谷歌、百度、必应等)会抓取这个文本文件,从而更快速、更全面地发现您网站上的所有页面。

这个脚本具体做了以下几件事:

  1. 加载 WordPress 环境: 通过 require('./wp-blog-header.php'); 加载 WordPress 的核心文件,这样脚本就能使用所有 WordPress 的内置函数。
  1. 设置内容类型: header("Content-type: text/txt"); 告诉浏览器或搜索引擎蜘蛛,这个页面的内容是纯文本(.txt),而不是一个网页(HTML)。
  1. 输出 URL 列表: 它会依次获取并输出以下几类页面的 URL:
  • 网站首页
  • 最新的 1000 篇文章
  • 所有的独立页面(比如"关于我们"、"联系我们"等)
  • 所有的文章分类页面
  • 所有的标签页面

下面是代码

复制代码
<?php
// 加载 WordPress 环境
require_once('./wp-blog-header.php');

// 设置一次性的 header,A5资源声明内容为纯文本
header("Content-Type: text/plain; charset=utf-8");
header("HTTP/1.1 200 OK");

// 定义要获取的最新文章数量
$posts_to_show = 1000;

// 1. 输出首页 URL (使用 WordPress 函数,能自动判断 http/https)
echo home_url('/') . "\n";

// 2. 输出文章页面的 URL 如:a5.org.cn
$posts = get_posts(['numberposts' => $posts_to_show, 'post_status' => 'publish']);
if ($posts) {
    foreach ($posts as $post) {
        // 使用 get_permalink() 获取文章链接
        echo get_permalink($post->ID) . "\n";
    }
}

// 3. 输出所有独立页面的 URL
$pages = get_pages();
if ($pages) {
    foreach ($pages as $page) {
        echo get_page_link($page->ID) . "\n";
    }
}

// 4. 输出所有分类页面的 URL
$categories = get_terms(['taxonomy' => 'category', 'hide_empty' => false]);
if ($categories && !is_wp_error($categories)) {
    foreach ($categories as $term) {
        echo get_term_link($term) . "\n";
    }
}

// 5. 输出所有标签页面的 URL
$tags = get_terms(['taxonomy' => 'post_tag', 'hide_empty' => false]);
if ($tags && !is_wp_error($tags)) {
    foreach ($tags as $tag) {
        echo get_term_link($tag) . "\n";
    }
}

// 脚本执行完毕
exit;

使用方法

  1. 创建一个名为 sitemap.php (或者其他你喜欢的名字) 的文件。
  1. 将上面这段修正后的代码复制并粘贴到文件中。
  1. 将这个文件上传到您 WordPress 网站的根目录(和 wp-config.php 文件在同一个地方)。
  1. 然后您就可以通过访问 https://a5.org.cn/sitemap.php 来查看这个纯文本网站地图了。
  1. 最后,将这个 URL 提交到各大搜索引擎的站长平台即可。
相关推荐
狂炫冰美式16 小时前
3天,1人,从0到付费产品:AI时代个人开发者的生存指南
前端·人工智能·后端
一千柯橘16 小时前
从摄影新手到三维光影师:Three.js 核心要素的故事
前端·three.js
南囝coding16 小时前
2025年CSS新特性大盘点
前端·css
c***V32317 小时前
前端框架对比:10个主流框架优缺点分析
前端·前端框架
栀秋66617 小时前
当我把 proto 打印出来那一刻,我懂了JS的原型链
前端·javascript
chxii17 小时前
PHP 配置全解析:Apache vs Nginx 的线程安全差异与 Windows 实战指南
运维·php
Cassie燁17 小时前
element-plus源码解读1——useNamespace
前端·vue.js
一直在学习的小白~17 小时前
npm发布脚手架流程
前端·npm·node.js
ErMao17 小时前
TypeScript的泛型工具集合
前端·javascript
涔溪17 小时前
如何解决微前端架构中主应用和微应用的通信问题?
前端·架构