XAMPP多端口配置:httpd-vhosts.conf详解
时间:2026-05-08 12:46:10 152浏览 收藏
本文深入解析了XAMPP中实现多端口本地开发环境的关键原理与实操要点,直击“配置了VirtualHost却无法访问”的普遍痛点——根本原因在于httpd-vhosts.conf本身不负责端口监听,真正起效的是httpd.conf中的Listen指令和未被注释的Include行;文章不仅厘清了配置逻辑层级(从全局监听→虚拟主机绑定→目录权限控制),还系统梳理了ERR_CONNECTION_REFUSED、403 Forbidden等典型错误的根源,涵盖防火墙拦截、hosts映射缺失、Apache版本权限语法差异、管理员权限重启等易忽略细节,并给出可直接复用的安全配置示例,助开发者一步到位搭建稳定、灵活的多项目并行调试环境。

直接说结论:XAMPP 的 httpd-vhosts.conf 本身不“支持多端口”——它只负责把某个端口(比如 *:8080)绑定到某个目录;真正让多端口生效的,是 httpd.conf 里的 Listen 指令。漏掉这一步,VirtualHost 配置再对也访问不了。
为什么加了 VirtualHost *:8080 还打不开?
常见错误现象是浏览器卡住、连接被拒绝,或直接报 ERR_CONNECTION_REFUSED。
httpd.conf中没加Listen 8080(或对应端口),Apache 根本不监听该端口Include conf/extra/httpd-vhosts.conf这行仍被注释(前面有#),整个httpd-vhosts.conf文件没被加载- Windows 防火墙或杀毒软件拦截了新端口(尤其 8080 以外的非常用端口)
httpd-vhosts.conf 里怎么写多端口配置?
每个 VirtualHost 块必须明确指定端口号,且 DocumentRoot 必须是绝对路径(不能以 ./ 或 htdocs/xxx 开头),末尾不加斜杠。
示例(添加到 httpd-vhosts.conf 文件末尾):
<VirtualHost *:8080>
DocumentRoot "C:/xampp/htdocs/project-a"
ServerName localhost:8080
<Directory "C:/xampp/htdocs/project-a">
Options Indexes FollowSymLinks
AllowOverride All
Require all granted
</Directory>
</VirtualHost>
<VirtualHost *:8081>
DocumentRoot "C:/xampp/htdocs/project-b"
ServerName localhost:8081
<Directory "C:/xampp/htdocs/project-b">
Options Indexes FollowSymLinks
AllowOverride All
Require all granted
</Directory>
</VirtualHost>
- 不要用
ServerAlias替代ServerName,否则部分 Apache 版本会忽略该虚拟主机 - 如果项目依赖
.htaccess(如 Laravel、WordPress),AllowOverride All不可省略 Require all granted是 Apache 2.4+ 的权限语法;若用旧版 XAMPP(Apache 2.2),需改用Order allow,deny+Allow from all
为什么访问时总报 403 Forbidden?
绝大多数情况不是 httpd-vhosts.conf 写错了,而是全局目录权限没放开。
在 httpd.conf 中找到类似这段(通常在 210–230 行附近):
<Directory />
AllowOverride none
Require all denied
</Directory>
必须改成:
<Directory />
AllowOverride none
Require all granted
</Directory>
- 这个配置控制 Apache 对所有路径的默认访问策略,
VirtualHost里的只能在此基础上收紧,不能突破它 - 改完后务必运行
httpd -t(在 XAMPP 控制面板里点 “Shell” 输入)验证语法,避免重启失败 - Windows 下修改
httpd.conf后需以管理员身份重启 Apache,否则可能因权限不足无法加载新配置
实际访问时要注意什么?
配置生效 ≠ 能直接用 http://localhost:8080 访问——你得确认三件事:
- 浏览器地址栏输的是
http://localhost:8080,不是https://(除非你配了 SSL) - 对应目录下有可识别的首页文件(如
index.php、index.html),否则会报 403(目录列表被禁)或 404 - 如果要用自定义域名(如
dev.project-a.com),必须同时在系统hosts文件中加映射:127.0.0.1 dev.project-a.com,否则 DNS 解析失败
最常被忽略的一点:改完所有配置后,必须彻底停止再启动 Apache(不是“重启”,XAMPP 的“重启”有时只重载模块,不重读 httpd.conf)。直接点“Stop”,等状态变灰,再点“Start”。
今天关于《XAMPP多端口配置:httpd-vhosts.conf详解》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于XAMPP的内容请关注golang学习网公众号!
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
102 收藏
-
200 收藏
-
319 收藏
-
353 收藏
-
195 收藏
-
163 收藏
-
152 收藏
-
242 收藏
-
365 收藏
-
337 收藏
-
405 收藏
-
274 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习