如何用PHP限制域名访问? | PHP安全配置优化指南

在PHP中限制域名访问可以通过检查HTTP请求中的Host头来实现,以下是几种实现方法:

php限制域名访问


方法1:直接比较域名(推荐)

// 允许访问的域名列表(不含端口)
$allowedDomains = [
    'example.com',
    'www.example.com',
    'app.example.com'
];
// 获取当前请求的域名(自动去除端口号)
$currentHost = strtolower(explode(':', $_SERVER['HTTP_HOST'])[0]);
// 验证域名
if (!in_array($currentHost, $allowedDomains)) {
    http_response_code(403); // 禁止访问
    exit('Access Denied: Invalid domain');
}
// 后续正常代码...

方法2:支持通配符的子域名匹配

$allowedPatterns = [
    'example.com',
    '*.example.com' // 允许所有子域名
];
$currentHost = strtolower(explode(':', $_SERVER['HTTP_HOST'])[0]);
$allowed = false;
foreach ($allowedPatterns as $pattern) {
    if ($pattern === $currentHost) {
        $allowed = true;
        break;
    }
    // 处理通配符 *.example.com
    if (strpos($pattern, '*') !== false) {
        $regex = '/^' . str_replace('*', '[^.]+', preg_quote($pattern, '/')) . '$/';
        if (preg_match($regex, $currentHost)) {
            $allowed = true;
            break;
        }
    }
}
if (!$allowed) {
    http_response_code(403);
    exit('Invalid domain');
}

方法3:通过.htaccess限制(更高效)

在网站根目录创建/修改.htaccess文件:

RewriteEngine On
RewriteCond %{HTTP_HOST} !^(www.)?example.com$ [NC]
RewriteCond %{HTTP_HOST} !^app.example.com$ [NC]
RewriteRule ^ - [F] # 返回403禁止访问

注意事项:

  1. 安全性

    • Host头可被伪造,敏感操作需额外验证(如Session/Cookie)
    • 此方法主要用于防止用户通过非常用域名访问
  2. 特殊场景处理

    php限制域名访问

    // 处理直接通过IP访问的情况
    if (!isset($_SERVER['HTTP_HOST']) || is_numeric(str_replace('.', '', $_SERVER['HTTP_HOST']))) {
        exit('Domain access only');
    }
  3. 端口处理

    • 代码中已自动剥离端口(如 example.com:8080example.com
    • 如需允许特定端口,需在允许列表中添加带端口的域名

完整示例代码:

<?php
// config.php - 域名验证
$allowed = [
    'example.com',
    'www.example.com',
    '*.app.example.com'
];
$host = $_SERVER['HTTP_HOST'] ?? '';
if (empty($host)) die('Invalid request');
// 剥离端口
$host = strtolower(explode(':', $host)[0]);
$valid = false;
foreach ($allowed as $domain) {
    // 完全匹配
    if ($domain === $host) {
        $valid = true;
        break;
    }
    // 通配符匹配
    if (strpos($domain, '*') !== false) {
        $pattern = '/^' . str_replace('*', '.*', preg_quote($domain)) . '$/';
        if (preg_match($pattern, $host)) {
            $valid = true;
            break;
        }
    }
}
if (!$valid) {
    http_response_code(403);
    include('forbidden.html'); // 自定义错误页
    exit;
}
// 后续业务代码...
?>

常见问题解决:

  1. 本地开发绕过

    // 在检测前加入开发环境白名单
    if ($_SERVER['REMOTE_ADDR'] === '127.0.0.1') return;
  2. 负载均衡场景

    php限制域名访问

    • 如果使用CDN/代理,检查X-Forwarded-Host头:
      $host = $_SERVER['HTTP_X_FORWARDED_HOST'] ?? $_SERVER['HTTP_HOST'];
  3. 大小写问题

    • 使用strtolower()统一转为小写比较

选择最适合你项目需求的方法,通常推荐使用.htaccess进行服务器级限制以减少PHP解析开销。

图片来源于AI模型,如侵权请联系管理员。作者:酷小编,如若转载,请注明出处:https://www.kufanyun.com/ask/290256.html

(0)
上一篇 2026年2月10日 03:39
下一篇 2026年2月10日 03:46

相关推荐

  • 免费虚拟主机-免费空间-免费主机-免费空间申请

        当下使用虚拟主机建站的用户越来越多,但是由于技术普及性的限制,部分用户操作有点难的。 下面小编将通过 酷番云的免费虚拟主机搭建使用最多的博客系统的教程w…

    2018年11月1日
    09.5K0
  • POLARDB数据库怎么购买?购买流程、价格及渠道的疑问解答

    POLARDB是阿里云推出的分布式关系型数据库服务,提供高可用、弹性伸缩、全托管等特性,适合企业级应用场景,购买POLARDB数据库需通过阿里云控制台完成,流程包含参数配置、计费模式选择等步骤,以下为详细说明:POLARDB购买流程详解购买POLARDB数据库主要分为登录控制台、创建实例、配置参数、选择计费模式……

    2026年1月8日
    0750
  • PS4国内服务器怎么连接?详细步骤与使用技巧全解析

    PS4国内服务器:连接与优化专业解析PS4作为全球知名的游戏主机平台,其在线服务PlayStation Network(PSN)为玩家提供了丰富的游戏内容与社交体验,由于网络环境的限制,国内玩家在连接PS4国际服务器时,常遭遇延迟过高、登录失败等问题,这背后涉及PS4的网络架构、国内网络政策及服务商的技术方案……

    2026年1月14日
    0650
    • 服务器间歇性无响应是什么原因?如何排查解决?

      根源分析、排查逻辑与解决方案服务器间歇性无响应是IT运维中常见的复杂问题,指服务器在特定场景下(如高并发时段、特定操作触发时)出现短暂无响应、延迟或服务中断,而非持续性的宕机,这类问题对业务连续性、用户体验和系统稳定性构成直接威胁,需结合多维度因素深入排查与解决,常见原因分析:从硬件到软件的多维溯源服务器间歇性……

      2026年1月10日
      020
  • PostgreSQL恢复数据库时,折扣计算规则与成本如何关联?

    PostgreSQL恢复数据库折扣PostgreSQL作为高性能的关系型数据库管理系统,其折扣机制(Discount)是优化查询性能的关键策略之一,折扣通过调整工作负载的资源分配(如并行查询的并行度、内存使用等),确保不同查询或表能获得合理的资源,从而提升整体系统性能,当数据库因故障恢复、迁移或版本升级后,折扣……

    2026年1月4日
    0540

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注