登录
首页 >  文章 >  php教程

XAMPP Apache禁止IP访问设置方法

时间:2026-05-20 08:06:46 479浏览 收藏

本文详解了在XAMPP环境下如何通过合理配置Apache的VirtualHost机制来彻底禁止直接通过IP地址访问网站——核心在于利用`httpd-vhosts.conf`顶部定义一个精确匹配服务器IP的“拒绝型”虚拟主机(`ServerName`设为实际IP、`Require all denied`),再在其后配置真实域名的“允许型”虚拟主机,依靠Apache基于Host头的路由匹配逻辑实现精准拦截;强调必须摒弃`.htaccess`或权限指令等错误思路,严格避免`NameVirtualHost`残留、`Include`未启用、`ServerName`误写为localhost或带端口等常见陷阱,确保IP访问返回403而域名访问完全正常。

XAMPP配置Apache禁止IP直接访问 XAMPP仅允许域名访问

直接结论:必须用 VirtualHost 捕获默认请求,不能靠 Require all granted.htaccess 解决——后者只管权限,不管路由匹配。

为什么直接访问 IP 会进到默认站点?

Apache 启动后,只要有一个 VirtualHost *:80 存在,且没显式声明 ServerName 匹配当前请求的 Host 头,它就会被当作“默认虚拟主机”兜底。你没配域名时输 http://192.168.1.100,Host 头就是那个 IP 字符串,Apache 找不到精确匹配,就扔给第一个或标记为 defaultVirtualHost ——于是你的网站照常打开,完全没拦住。

配置两个 VirtualHost 拦截 IP 访问

核心思路是:让 IP 请求命中一个“空”或“拒绝型”的虚拟主机,而把合法域名交给另一个。顺序和 ServerName 值必须严格对应:

  • httpd-vhosts.conf 最顶部添加第一个 VirtualHostServerName 设为你服务器的公网/局域网 IP(如 192.168.1.100),DocumentRoot 指向一个空目录(如 C:/xampp/htdocs/denied),并在其 块中写 Require all denied
  • 第二个 VirtualHost 写你的真实域名,比如 ServerName mysite.localDocumentRoot 指向真实项目路径,Require all granted
  • 确保两个 VirtualHost 都监听 *:80,且没有遗漏 Listen 80(已在 httpd.conf 中启用)
  • 重启 Apache,再用浏览器访问 http://192.168.1.100,应返回 403;访问 http://mysite.local 则正常

ServerName 写 IP 还是域名?

必须写实际 IP 地址(不是 127.0.0.1,除非你只在本机测试),否则无法匹配 Host 头。常见错误包括:

  • 写成 ServerName localhost —— 浏览器访问 IP 时 Host 头不是 localhost,不匹配
  • 写成 ServerName _ 或留空 —— Apache 会忽略该字段,退化为默认匹配
  • IP 地址带端口(如 192.168.1.100:80)—— ServerName 不接受端口,会解析失败
  • 没在系统 hosts 文件里加 127.0.0.1 mysite.local —— 域名根本解析不了,压根进不了第二个 VirtualHost

别碰 httpd.conf 里的 NameVirtualHost

Apache 2.4+ 已废弃 NameVirtualHost 指令,XAMPP 自带版本(通常 2.4.52+)如果还保留这行,反而可能引发警告甚至启动失败。检查 httpd.conf,确认已注释或删除所有 NameVirtualHost 行。真正起作用的是 VirtualHost 块自身的 ServerName 和监听地址组合。

最容易被忽略的一点:改完 httpd-vhosts.conf 后,必须确保 httpd.conf 中这一行没被注释:Include "conf/extra/httpd-vhosts.conf"。漏掉这句,所有虚拟主机配置都不生效,IP 访问依然直通默认站点。

好了,本文到此结束,带大家了解了《XAMPP Apache禁止IP访问设置方法》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多文章知识!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>