0

0

如何在 Apache 404 错误页中获取原始请求路径

聖光之護

聖光之護

发布时间:2026-02-17 10:31:16

|

907人浏览过

|

来源于php中文网

原创

如何在 Apache 404 错误页中获取原始请求路径

本文详解如何通过 .htaccess 配置自定义 404 页面,并在 PHP 脚本中安全、准确地获取用户访问的原始 URL 路径(如 /example),适用于 SEO 友好跳转、动态错误处理或路由兜底等场景。

本文详解如何通过 `.htaccess` 配置自定义 404 页面,并在 php 脚本中安全、准确地获取用户访问的原始 url 路径(如 `/example`),适用于 seo 友好跳转、动态错误处理或路由兜底等场景。

当用户访问一个不存在的路径(例如 https://test.de/example),Apache 默认返回标准 404 响应。若希望将其优雅降级至自定义 PHP 页面(如 404.php),并保留原始请求路径用于后续逻辑处理(如日志记录、智能重定向或前端渲染),需正确配置服务器与脚本协同机制。

✅ 正确配置 .htaccess

在网站根目录下创建或编辑 .htaccess 文件,添加以下指令:

ErrorDocument 404 /404.php

⚠️ 注意:路径 /404.php 必须以斜杠开头,表示相对于站点根目录(DocumentRoot);不能写成 ./404.php 或 404.php,否则 Apache 将无法正确定位。

✅ 在 404.php 中获取原始请求路径

Apache 在触发 ErrorDocument 时,会保留原始请求的环境变量。此时,$_SERVER['REQUEST_URI'] 的值即为用户最初输入的完整路径(含查询参数),例如:

AI at Meta
AI at Meta

Facebook 旗下的AI研究平台

下载
  • 用户访问 https://test.de/example?ref=home → $_SERVER['REQUEST_URI'] 返回 /example?ref=home
  • 用户访问 https://test.de/abc/def/ → 返回 /abc/def/

因此,在 404.php 中可直接使用:

<?php
$originalPath = $_SERVER['REQUEST_URI'] ?? '/';
// 安全截取路径部分(不含查询参数)
$pathOnly = parse_url($originalPath, PHP_URL_PATH);

echo "<h2>未找到页面:</h2>";
echo "<p>您尝试访问:<code>" . htmlspecialchars($pathOnly) . "</code></p>";

// 示例:根据路径前缀做智能跳转
if (str_starts_with($pathOnly, '/api/')) {
    http_response_code(404);
    echo "<p>API 接口不存在,请检查文档。</p>";
} elseif ($pathOnly === '/admin') {
    header('Location: /login?redirect=' . urlencode($pathOnly));
    exit;
}
?>

⚠️ 关键注意事项

  • 不要依赖 $_SERVER['REDIRECT_URL'] 或 $_SERVER['REDIRECT_QUERY_STRING']:这些变量在 ErrorDocument 场景下行为不稳定,尤其在多层重写或 FastCGI 环境中可能为空或被覆盖。
  • 始终对输出内容进行 HTML 转义:$_SERVER['REQUEST_URI'] 可被恶意构造(如含 XSS 载荷),直接输出存在安全风险,务必使用 htmlspecialchars() 处理。
  • 确保响应状态码为 404:虽然 Apache 已发送 404 状态,但若 404.php 内部执行了 header('Location: ...') 或 http_response_code(200),将覆盖原始状态码,影响搜索引擎和爬虫判断。如需重定向,请显式设置:
    http_response_code(302); // 或 301
    header('Location: /fallback');
    exit;
  • 避免循环重定向:确保 404.php 自身路径不会触发新的 404(例如文件权限错误、路径拼写错误),建议部署前用 curl -I https://test.de/404.php 验证其可访问性。

✅ 总结

通过 ErrorDocument 404 /404.php 配置 + $_SERVER['REQUEST_URI'] 读取,即可轻量、可靠地捕获原始请求路径。该方案兼容所有标准 Apache 部署(包括共享主机),无需启用 mod_rewrite 或复杂规则,是构建健壮前端路由或错误处理系统的基石实践。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

452

2023.06.14

linux常见下载安装工具
linux常见下载安装工具

linux常见下载安装工具有APT、YUM、DNF、Snapcraft、Flatpak、AppImage、Wget、Curl等。想了解更多linux常见下载安装工具相关内容,可以阅读本专题下面的文章。

181

2023.10.30

location.assign
location.assign

在前端开发中,我们经常需要使用JavaScript来控制页面的跳转和数据的传递。location.assign就是JavaScript中常用的一个跳转方法。通过location.assign,我们可以在当前窗口或者iframe中加载一个新的URL地址,并且可以保存旧页面的历史记录。php中文网为大家带来了location.assign的相关知识、以及相关文章等内容,供大家免费下载使用。

232

2023.06.27

apache是什么意思
apache是什么意思

Apache是Apache HTTP Server的简称,是一个开源的Web服务器软件。是目前全球使用最广泛的Web服务器软件之一,由Apache软件基金会开发和维护,Apache具有稳定、安全和高性能的特点,得益于其成熟的开发和广泛的应用实践,被广泛用于托管网站、搭建Web应用程序、构建Web服务和代理等场景。本专题为大家提供了Apache相关的各种文章、以及下载和课程,希望对各位有所帮助。

417

2023.08.23

apache启动失败
apache启动失败

Apache启动失败可能有多种原因。需要检查日志文件、检查配置文件等等。想了解更多apache启动的相关内容,可以阅读本专题下面的文章。

937

2024.01.16

Java 流式处理与 Apache Kafka 实战
Java 流式处理与 Apache Kafka 实战

本专题专注讲解 Java 在流式数据处理与消息队列系统中的应用,系统讲解 Apache Kafka 的基础概念、生产者与消费者模型、Kafka Streams 与 KSQL 流式处理框架、实时数据分析与监控,结合实际业务场景,帮助开发者构建 高吞吐量、低延迟的实时数据流管道,实现高效的数据流转与处理。

107

2026.02.04

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2564

2024.08.16

什么是搜索引擎
什么是搜索引擎

搜索引擎是一种互联网工具,用于帮助用户在网上查找信息。搜索引擎的目标是提供最准确、最有价值的搜索结果,使用户能够快速找到所需的信息。本专题为大家提供搜索引擎相关的各种文章、以及下载和课程。

445

2023.08.02

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

283

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
RunnerGo从入门到精通
RunnerGo从入门到精通

共22课时 | 1.8万人学习

尚学堂Mahout视频教程
尚学堂Mahout视频教程

共18课时 | 3.2万人学习

Linux优化视频教程
Linux优化视频教程

共14课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号