最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
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,添加如下虚拟主机块:
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 All和Require all granted - .htaccess 必须放在 public/ 目录下,内容推荐使用 TP6 兼容写法:
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=mbstringextension=opensslextension=pdo_mysql - 若用 XAMPP,建议开启 OPcache 加速 CLI 命令:
opcache.enable=1(默认是 0)
相关文章
- 2026年Notion AI设计场景用法:草稿生成与风格约束说明 06-20
- 京东在哪里可以解绑银行卡 06-20
- 2026年Notion AI响应缓慢:网络、缓存与账户配置排查 06-20
- 2026年Notion AI团队协作:权限、工作流与配置要点 06-20
- Notion AI企业版新手入门:账号权限与工作空间配置说明 06-20
- 如何用python创建项目 06-20