一聚教程网:一个值得你收藏的教程网站

最新下载

热门教程

Windows下XAMPP搭建ThinkPHP环境:虚拟主机与伪静态配置指南

时间:2026-06-20 10:02:47 编辑:袖梨 来源:一聚教程网

正确做法是用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 强制暴露的问题,都出在虚拟主机路径映射和伪静态开关没对齐上。

虚拟主机配置:让 public/ 成为实际入口,又不破坏项目结构

ThinkPHP 6+ 强制所有请求经 public/index.php,但不能直接把 Apache 的 DocumentRoot 改成 public/——否则 CLI 命令(如 php think route:list)会找不到配置文件,IDE 调试也会错位。

正确做法是用 Apache 的 Alias 映射 URL 到 public/,同时保留项目根目录为 DocumentRoot:

  • 编辑 XAMPPapacheconfextrahttpd-vhosts.conf,添加如下虚拟主机块:
zuojiankuohaophpcnVirtualHost *:80>
  ServerName tp.local
  DocumentRoot "D:/www/myapp"
  <Directory "D:/www/myapp">
    AllowOverride None
    Require all denied
  </Directory>
  Alias / "D:/www/myapp/public/"
  <Directory "D:/www/myapp/public/">
    AllowOverride All
    Require all granted
  </Directory>
</VirtualHost>
  • 修改系统 C:WindowsSystem32driversetchosts,加入:
    127.0.0.1 tp.local
  • 重启 Apache,访问 http://tp.local/ 即可加载 public/ 下的内容,且命令行与 IDE 仍以项目根为准

伪静态启用:三步缺一不可

XAMPP 默认不执行 .htaccess,哪怕你放对位置、写对规则,只要下面三点有一项没到位,就会 404 或 403:

立即学习“PHP免费学习笔记(深入)”;

  • 启用 mod_rewrite 模块:打开 XAMPPapacheconfhttpd.conf,搜索 LoadModule rewrite_module,删掉行首的 #;保存后重启 Apache
  • 对应目录 AllowOverride All:找到 <Directory "D:/www/myapp/public/"> 这一段(必须是 public/ 所在路径),确认里面有 AllowOverride AllRequire all granted
  • .htaccess 必须放在 public/ 目录下,内容推荐使用 TP6 兼容写法:
RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)$ index.php?s=$1 [QSA,L]
  • 注意:[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 是否完整——它们的作用就是放过真实存在的文件和目录

PHP 扩展与版本校验

ThinkPHP 6.x 要求 PHP ≥ 7.2.5,推荐 8.0+。XAMPP 8.2+ 已满足,但需手动确认关键扩展已启用:

  • 打开 XAMPP 控制面板 → Apache → Config → PHP (php.ini)
  • 确保以下扩展未被注释:
    extension=mbstring
    extension=openssl
    extension=pdo_mysql
  • 若用 XAMPP,建议开启 OPcache 加速 CLI 命令:
    opcache.enable=1(默认是 0)

热门栏目