为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 提交到各大搜索引擎的站长平台即可。
相关推荐
Jackson__8 分钟前
做了一段时间的AI coding后,我终于搞清了 CLI 和 MCP 的区别
前端·agent·ai编程
IT_陈寒3 小时前
JavaScript项目实战经验分享
前端·人工智能·后端
用户47949283569153 小时前
6w star,GitHub 趋势第一的 Ponytail,这个agent插件到底在火什么
前端·后端
薛定喵的谔5 小时前
我开源了一个精致的 Next.js 博客模板:Skyplume
前端·前端框架·next.js
张龙6875 小时前
构建生产级 AI Agent:工具调用与记忆架构实战指南
前端
kyriewen6 小时前
2026 年了,还在用 Node.js?Bun 迁移实战:20 分钟搞定,附踩坑记录
前端·javascript·node.js
青山Coding8 小时前
Cesium应用(八):物体运动的实现思路
前端·cesium
用户41659673693558 小时前
Android WebView 加载 file:// 离线页面调试教程
android·前端
Asmewill8 小时前
curl命令学习笔记一
前端
我是一只快乐的小螃蟹8 小时前
1.2 ArrayList 源码解析
前端