如何用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

相关推荐

  • pps无法连接服务器

    pps无法连接服务器是用户在使用特定软件或服务时常见的困扰,它不仅影响正常功能使用,还可能导致数据同步中断或服务无法激活,该问题由网络、软件、服务器等多重因素引发,需系统排查才能快速解决,本文将从常见原因、解决步骤及预防措施入手,帮助用户高效定位并修复问题,常见原因分析“pps无法连接服务器”的表现多样,需结合……

    2025年12月28日
    01090
  • PolarDB云数据库是什么?详细介绍其优势、性能与适用场景,你关心的疑问都在这里!

    {PolarDB云数据库详细介绍}PolarDB是阿里云自主研发的云原生关系型数据库产品,自2019年正式商用以来,凭借其混合架构设计、多引擎支持与弹性伸缩能力,成为企业级核心业务系统的首选方案,它融合了MySQL、PostgreSQL、Oracle等传统数据库的优势,通过云原生技术实现了数据库的自动化运维、成……

    2026年1月13日
    0810
  • php监控linux服务器脚本怎么写?php监控linux服务器脚本教程

    在服务器运维领域,构建一套高效、稳定的监控系统是保障业务连续性的基石,PHP监控Linux服务器的核心结论在于:利用PHP的灵活性结合Linux系统原生工具(如Shell命令、系统文件),通过定时任务与Web界面联动,能够以极低的成本实现涵盖CPU、内存、磁盘、网络及服务端口的全方位实时监控,并具备自动报警与日……

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

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

      2026年1月10日
      020
  • PHP怎么抓取远程图片?如何保存到本地服务器?

    构建一个高效的PHP远程图片抓取类,核心在于利用cURL模拟浏览器行为、严格校验图片流以及结合云存储实现持久化,从而解决传统方法在防盗链、超时和并发处理上的不足,专业的图片抓取不仅仅是下载文件,更是一个包含请求伪装、错误重试、格式验证及存储优化的系统工程, 只有通过封装健壮的类结构,才能在复杂的网络环境中保证图……

    2026年2月28日
    0402

发表回复

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