正确做法是用Apache的Alias映射URL到public/,保留项目根为DocumentRoot,并确保mod_rewrite启用、AllowOverride All生效、.htaccess置于public/目录且含RewriteRule ^(.*?)$ index.php?s=$1 [QSA,L]规则。
在 Windows 下用 XAMPP 搭建 ThinkPHP 环境,核心不是装完就跑通,而是让 Apache 正确识别入口、路由和重写规则。很多 404、403 或 index.php 强制暴露的问题,都出在虚拟主机路径映射和伪静态开关没对齐上。
ThinkPHP 6+ 强制所有请求经 public/index.php,但不能直接把 Apache 的 DocumentRoot 改成 public/——否则 CLI 命令(如 php think route:list)会找不到配置文件,IDE 调试也会错位。
正确做法是用 Apache 的 Alias 映射 URL 到 public/,同时保留项目根目录为 DocumentRoot:
XAMPPapacheconfextrahttpd-vhosts.conf,添加如下虚拟主机块:C:WindowsSystem32driversetchosts,加入:127.0.0.1 tp.local
http://tp.local/ 即可加载 public/ 下的内容,且命令行与 IDE 仍以项目根为准XAMPP 默认不执行 .htaccess,哪怕你放对位置、写对规则,只要下面三点有一项没到位,就会 404 或 403:
立即学习“PHP免费学习笔记(深入)”;
XAMPPapacheconfhttpd.conf,搜索 LoadModule rewrite_module,删掉行首的 #;保存后重启 Apache<Directory "D:/www/myapp/public/"> 这一段(必须是 public/ 所在路径),确认里面有 AllowOverride All 和 Require all granted
[QSA,L] 不可省略;不要加 RewriteBase,除非你的项目在子目录(如 /myapp/),才需写 RewriteBase /myapp/
403 Forbidden:大概率是 Options +FollowSymLinks 缺失。在 <Directory "D:/www/myapp/public/"> 块内补上:Options +FollowSymLinks -Multiviews
404 且 URL 含 index.php:检查 config/app.php 中 'url_route_on' => true 是否开启;再确认 mod_rewrite 是否真被加载(访问 http://localhost/phpinfo.php,搜 mod_rewrite)
访问静态资源(如 CSS/JS)404:说明 Apache 把请求错误地交给了 index.php。检查 .htaccess 中两条 RewriteCond 是否完整——它们的作用就是放过真实存在的文件和目录
ThinkPHP 6.x 要求 PHP ≥ 7.2.5,推荐 8.0+。XAMPP 8.2+ 已满足,但需手动确认关键扩展已启用:
extension=mbstringextension=opensslextension=pdo_mysql
opcache.enable=1(默认是 0)